Creating your own OpenID Connect server with ASOS: testing your authorization server with Postman
This post is the eighth part of a series of blog posts entitled Creating your own OpenID Connect server with ASOS:
- Introduction
- Choosing the right flow(s)
- Registering the middleware in the ASP.NET Core pipeline
- Creating your own authorization provider
- Implementing the resource owner password credentials grant
- Implementing the authorization code and implicit flows
- Adding custom claims and granting scopes
- Testing your authorization server with Postman
- Conclusion
The sample used in this post can be found in the AspNet.Security.OpenIdConnect.Samples
repository, that also hosts the Cordova, MVC and SignalR samples for ASOS.
For clarity, it implements both the authorization code flow and the password flow, but doesn't use any membership stack (the user credentials are hardcoded in the authorization provider class and a fake identity is always used to create tokens).
To test REST services, one of the easiest options is indisputably to use Postman. If you're not already familiar with Postman, I encourage you to read the documentation.
Retrieving an access token using the resource owner password credentials grant
Using the password flow with Postman is quite straightforward:
- Select
POST
as the HTTP method. - Fill the
Request URL
input with the absolute address of the token endpoint. - Click on the
Body
tab and choose thex-www-form-urlencoded
encoding. - Add the OAuth2 parameters required by the specification, as shown on this screenshot:
data:image/s3,"s3://crabby-images/26b19/26b1914cfc303ff6866ee0925b09b427c1651fa3" alt=""
1
|
POST /connect/token
|
If your request is valid, an access token, an identity token and a refresh token should be returned:
data:image/s3,"s3://crabby-images/f7f3f/f7f3f21662c42982c271338a03ce849de2c975e5" alt=""
While the access token and the refresh token are encrypted and opaque for the client, the identity token can be easily deserialized using a tool like jwt.io
:
data:image/s3,"s3://crabby-images/a9573/a9573f8d1b2ab6674bd9889f646d5bd200610fce" alt=""
Making an API request using the access token issued by ASOS
To attach an access token to an API request, click on the Headers
tab and add a new Authorization
header. Make sure to prefix the header value with the Bearer
scheme (plus a space separating the scheme and the access token).
data:image/s3,"s3://crabby-images/f1057/f10577c8c23650fd684bb3175ea241af4b66100c" alt=""
1
|
GET /api/message
|
If the access token is still valid, you should see this exact output message:
data:image/s3,"s3://crabby-images/5fe5a/5fe5ad9dc12264395781ed191f3822d3df6076b7" alt=""
Retrieving an access token using the authorization code flow
Using the authorization code flow is generally more complicated, but Postman offers a very simple and convenient way to retrieve an access token without having to write a single request.
To start a new authorization flow, click on the Authorization
tab, select OAuth 2.0
and press Get new access token
:
data:image/s3,"s3://crabby-images/48d17/48d17ccf219ff722c023e2c804f463e6e0dc7fcd" alt=""
When the OAuth 2.0 configuration popup appears, select Authorization code
in the dropdown list and populate the required fields by specifying the authorization endpoint
, the token endpoint
, the client identifier
, the callback URL
and optionally, a scope
and a token name
.
When running the sample from a location that is not accessible from Internet, make sure to check the Request access token locally
checkbox.
data:image/s3,"s3://crabby-images/67dce/67dce26c093474e2981cf6d6e6389ed0a7ad82ca" alt=""
If the request parameters are valid, you should be prompted by the authorization consent form returned by AuthorizationController
:
data:image/s3,"s3://crabby-images/29610/29610095d939252e8506c830be98b121a3228876" alt=""
After granting the authorization, Postman will send a token request and retrieve a new access token it will add under the Existing tokens
list:
data:image/s3,"s3://crabby-images/39f06/39f066d41b6859e47e0dc41f4a0eb9d653f3bc4a" alt=""
Select Header
in the dropdown list and press Use token
to tell Postman to attach the access token to the API request, like you manually did in the previous step. If the token is still valid, clicking on Send
will return a successful message:
data:image/s3,"s3://crabby-images/5fe5a/5fe5ad9dc12264395781ed191f3822d3df6076b7" alt=""
Next part: Conclusion.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
2022-05-19 LINQ to SQL使用教程
2022-05-19 Dapper的完整扩展(转)
2022-05-19 C# SqlBuilder類代碼示例
2022-05-19 后端 在 Dapper 中使用 SqlBuilder 達成動態條件
2022-05-19 dapper的nitOfWork之介绍
2022-05-19 .NetCore中使用Dapper