使用PostMan Canary测试受Identity Server 4保护的Web Api

虚幻大学 xuhss 778℃ 0评论

Python微信订餐小程序课程视频

https://edu.csdn.net/course/detail/36074

Python实战量化交易理财系统

https://edu.csdn.net/course/detail/35475
《Asp.Net Core: Swagger 与 Identity Server 4》一文中介绍了如何生成受保护的Web Api的Swagger文档,本文介绍使用PostMan Canary测试受Identity Server 4保护的Web Api。

首先搭建一下Identity Server 4的环境,并且创建一个测试用的Web Api和访问Web Api的客户端,这部分在系列文章《Identity Server 4 从入门到落地》中有详细的介绍。
Identity Server 4 Admin的代码和测试用Web Api和Client的代码可以从Github下载:
https://github.com/zhenl/IDS4Admin
https://github.com/zhenl/IDS4ClientDemo

这里只列出测试用Web Api项目appsettings.json中的配置项:

  "IdentityServer4Api": {
    "Authority": "http://host.docker.internal:4010",
    "CorsOrgins": [
      "http://host.docker.internal:5291"
    ],
    "Policies": [
      {
        "Name": "ApiScope",
        "RequireAuthenticatedUser": "true",
        "Claims": [
          {
            "ClaimType": "scope",
            "AllowValues": [ "testapi" ]
          }
        ]
      }
    ],

访问这个Web Api的测试用Web应用appsettings.json中相关配置项:

  "IdentityServer4Client": {
    "Authority": "http://host.docker.internal:4010",
    "ClientId": "testclient",
    "ClientSecret": "secret",
    "ResponseType": "code",
    "SaveTokens": "true",
    "RequireHttpsMetadata": "false",
    "Scopes": [ "openid", "profile", "testapi" ],
    "JsonKeys": []

  }

我们使用最新的PostMan Canary进行测试,下载地址https://www.postman.com/downloads/canary/。安装完成后,就可以访问Web Api了。

如果直接访问 Web Api,会提示401错误:
2ebe36c2684a08151794e67c48d114aa - 使用PostMan Canary测试受Identity Server 4保护的Web Api

我们需要在PostMan中实现认证,才能访问受保护的Web Api。我们已经在认证中心设置了可以访问Web Api的Client,信息如下:

Client ID testclient
Client Secret secret
Callback URL http://host.docker.internal:5291/signin-oidc
Web Api Scope Scope

现在,在PostMan中进入Authorization分页:

683b5eee1d49b5b8f0c248e1bf21f968 - 使用PostMan Canary测试受Identity Server 4保护的Web Api

选择认证类型为OAuth2.0:
8a6d85e5e2bdbb75e3e0d7b2283ce731 - 使用PostMan Canary测试受Identity Server 4保护的Web Api
在右边出现认证需要的参数表单,其中Grant Type选择Authorization Code(With PKCE),说明我们使用OpenID Connect。其它参数参考已经配置的Client 参数。
497248a47ff61b9c966625a9395785ae - 使用PostMan Canary测试受Identity Server 4保护的Web Api
还需要说明的是,认证的地址为:[认证服务地址]/connect/authorize,在这个例子中这个地址为http://host.docker.internal:4010/connect/authorize。获取Token的URL为[认证服务地址]/connect/token,在这个例子中地址为:http://host.docker.internal:4010/connect/token
参数填写完成后,点击Get Access Token按钮:
affd7fd6ab2fe437853e5d436dfae245 - 使用PostMan Canary测试受Identity Server 4保护的Web Api
如果设置正确的话,会弹出认证页面,输入用户名,密码,认证完成后,PostMan关闭认证页面,并返回Access Token:
c5cef3b10e2e66dbbb235c291b93825a - 使用PostMan Canary测试受Identity Server 4保护的Web Api
点击Use Token,Token被自动填写到访问页面:
487841163cf92239b3ad46f7a0c41b14 - 使用PostMan Canary测试受Identity Server 4保护的Web Api
这时再次按Send访问Web Api,可以正确地获取返回数据了:
83d8eaa65bdfe79023a30c4fc529505f - 使用PostMan Canary测试受Identity Server 4保护的Web Api

转载请注明:xuhss » 使用PostMan Canary测试受Identity Server 4保护的Web Api

喜欢 (0)

您必须 登录 才能发表评论!