AspNetCore 中使用 InentityServer4(2)
基于上一篇文章 實現對IdnetityServer4 服務的使用
1:添加接口解決方案,并且使接口受認證服務的保護:
首先在解決方案中添加Api項目如下圖所示:
在API項目中添加Nuget 引用 如下圖所示:
Install-Package IdentityServer4.AccessTokenValidation -Version 2.6.0
添加此包的作用是,在API中添加驗證服務,使Api 受驗證服務的保護,如果消費者在調用此受保護的接口的時候,傳入的令牌沒有通過驗證將不允許進行訪問
在Startup 中添加身份認證服務如下圖所示:
以上有關驗證服務我們就配置好了,但是如果我們現在進行項目啟動并且調用其中的方法時會發現和平常并沒有什么區別:如圖演示
是因為我們只是進行了配置并沒有進行使用:使用如下:
引用:using Microsoft.AspNetCore.Authorization 這是AspNetCore的認證命命空間
我們在Api 方法Get()上進行使用如下 注意在Get(int Id)方法上我們并沒有進行使用項目啟動后我們嘗試調用結果如下:
?
這是未使用驗證的方法Get(int Id):調用成功
下面是使用驗證的方法:調用失敗未授權
?
如果說我們想讓整個控制器中的所有方法都使用,在控制器上方進行使用就行:如下圖
?上面的演示結果都是失敗的,下面我們加上密鑰去訪問一下:結果如下圖所示
密鑰是用客戶端代碼請求來的,上面的演示結果都是使用Postman 進行調用演示:演示一下客戶端使用
2:添加客戶端解決方案,并請求密鑰完成調用:
以控制臺進行演示一下:
新建控制臺:并且引用IdentityModel包 如下圖所示:
因為IdentityModel客戶端只提供了異步等待請求的方式去請求認證服務器,所以 我們首先更改一下控制臺的屬性步驟如下
點擊打開控制臺屬性 —》點開 高級 如圖
修改高級語言版本為7.1以上, 如圖:注意: 7.1以上才支持 控制臺入口方法 Main 支持異步等待操作
環境好了之后下面我們請求一下,認證服務,并且演示模擬調用接口操作,代碼如下:
?結果如圖:
?
原文鏈接:https://www.cnblogs.com/szlblog/p/9568472.html
.NET社區新聞,深度好文,歡迎訪問公眾號文章匯總 http://www.csharpkit.com
總結
以上是生活随笔為你收集整理的AspNetCore 中使用 InentityServer4(2)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 你需要知道的这几种 asp.net co
- 下一篇: 当我们谈高性能时,我们谈些什么?(送书活