基於上一篇文章 實現對IdnetityServer4 服務的使用 1:添加介面解決方案,並且使介面受認證服務的保護: 首先在解決方案中添加Api項目如下圖所示: 在API項目中添加Nuget 引用 如下圖所示: Install-Package IdentityServer4.AccessTokenV ...
基於上一篇文章 實現對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 支持非同步等待操作
環境好了之後下麵我們請求一下,認證服務,並且演示模擬調用介面操作,代碼如下:
結果如圖:
有不足之處 希望大家指出相互學習,
本文原創:轉載請註明出處 謝謝!