Identity Server 4 - Hybrid Flow - 保護API資源

来源:https://www.cnblogs.com/cgzl/archive/2018/07/07/9276278.html
-Advertisement-
Play Games

這個系列文章介紹的是Identity Server 4 的 Hybrid Flow, 前兩篇文章介紹瞭如何保護MVC客戶端, 本文介紹如何保護API資源. 保護MVC客戶端的文章: https://www.cnblogs.com/cgzl/p/9253667.html, https://www.cn ...


這個系列文章介紹的是Identity Server 4 的 Hybrid Flow, 前兩篇文章介紹瞭如何保護MVC客戶端, 本文介紹如何保護API資源.

保護MVC客戶端的文章: https://www.cnblogs.com/cgzl/p/9253667.html,  https://www.cnblogs.com/cgzl/p/9268371.html

相關代碼: https://github.com/solenovex/Identity-Server-4-Tutorial-Code 裡面03那部分.

 

回顧 Hybrid Flow

回顧一下該項目使用的流程

圖裡有IDP (Identity Provider, 我例子里是用Identity Server 4構建的項目)和客戶端(我的例子里是MVC客戶端).

在上面流程走完之後, MVC客戶端獲得了Access Token, MVC客戶端驗證Access Token併成功後, 就可以使用Access Token來訪問被保護的API資源了, 而Access Token會在被保護的API那裡再次進行驗證.

 

保護API

首先在IDP里配置一個返回ApiResoruce的方法:

和IdentityResource類似, ApiResource就是與API相關的scopes.

 

在Client配置那裡, 把這個ApiResource的名字添加到允許的scopes里:

 

最後在IDP的startup里, 註冊ApiResources:

 

現在來到MVC客戶端這裡, 需要把上面的scope添加上:

 

最後來到API項目, 首先確保使用HTTPS:

 

API項目還需要安裝IdentityServer4.AccessTokenValidation這個包, 可以通過Nuget安裝.

安裝後, 還需要進行配置 (官方文檔: https://identityserver4.readthedocs.io/en/release/quickstarts/1_client_credentials.html#adding-an-api): 

其中IdentityServerAuthenticationDefaults.AuthenticationScheme 就是 “Bearer” 的意思, 這裡使用的就是這個方案.

AddIdentityServerAuthentication()方法註冊了Access Token 驗證的處理者. 裡面Authority就是IDP的URI, ApiName就是IDP里配置的API的名字.

 

在Startup的Configure方法里, 還需要把它添加到管道:

要確保它在UseMVC之前調用.

 

我在API項目里使用過濾器為所有的Controller都加上了授權過濾:

當然也可以在具體的Controller或Action級寫上這個:

無論如何現在訪問Country資源是需要授權的.

 

回到MVC客戶端, 在Home的Contact Action里調用CountryAPI資源:

 

 

下麵測試一下未使用Access Token訪問被保護的Country資源的情況, 重新操作可以看到用戶同意授權頁面出現了剛纔配置的API資源名:

在訪問Contact頁面的時候, 提示未授權:

 

那就用之前介紹過的方法來獲取Access Token並設置Authorization Header為 “Bearer [AccessToken]” 即可:

 

再修改一下Contact頁面, 顯示Access Token:

 

重新操作, 就可以看到Country資源數據了:

 

Access Token

去jwt.io對Access Token進行解碼:

看一下aud (audience, 觀眾) 這個屬性, 它有兩個值, 第一個是指IDP那邊對資源 (調用用戶信息端點), 第二個就是指API那個項目.

這個屬性說明這個access token是為它們倆準備的.

而scope裡面的“restapi”就是aud裡面的“restapi”, 所以這個token允許被用來訪問我們的“restapi”.

而scope裡面的“profile”等scopes是對應另一個aud的值, 這些scopes來自IDP那裡.

 

現在Access Token有這些claims, API也就能得到這些claims, 但是有時API還需要用戶身份相關的claims.

修改IDP的ApiResource配置即可:

 

再次操作後, 查看token, 就可以看到我剛剛添加的那兩個claim了:

 

而role這個claim, 在API里是可以被識別成角色的, 如果我在API的Action上設置許可權如下:

那麼, Nick這個用戶就可以得到Country數據, 而Dave則會顯示403 Forbidden:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 單例模式是java的一種設計模式,它是指在設計一個類時需要保證在整個程式運行期間針對該類值存在一個實例對象。例: class Single{ private static Single INSTANCE = new Single(); private Single() {} public stati ...
  • 原創 以下內容來自《Java 2實用教程》,主編:耿祥義、張躍平 鑒於面向抽象編程和麵向介面編程思維培養的重要性,寫此博客鞏固。 面向抽象編程: 在設計程式時,經常會使用到abstract類,其原因是,abstract類只關心操作,而不關心這些操作具體的實現細節, 可以使程式的設計者把主要精力放在程 ...
  • Android屏幕解鎖圖案利用Python破解 在 Android 手機上,我們可以通過設置鎖定圖案來當做密碼對手機鎖屏。 在 Android 存儲時使用的是明文轉換後採用散列方式存儲。 這種密碼有三個要求: 最少四個數 最多九個數 無重覆數 加密存儲過程如下: 第一步:隨便輸入一個圖形進行測試 可 ...
  • 第一步:頁面分析 我們要抓取的商品頁面: 這裡我們用正則表達式匹配出該段信息。進一步可以發現它是一個json數據,用json.loads()解析。解析後我們可以藉助線上工具可以查看數據的層級結構,找到需要數據的key。這裡我們把頁面分析與數據提取放到一塊來講了,代碼邏輯: 第三步:開始抓取 第四步: ...
  • 在我們碼字過程中,單元測試是必不可少的。但在從業過程中,很多開發者卻對單元測試望而卻步。有些時候並不是不想寫,而是常常會碰到諸如不能模擬一次HTTP請求,不能讀取配置文件,測試類的構造參數太多等問題,讓開發者放下了碼字的腳步。這些問題確實存在,但它們阻止不了我們那顆要寫單元測試的心。單元測試的優點很... ...
  • 在很多時候我們在生成C#exe文件時,如果在工程里調用了dll文件時,那麼如果不加以處理的話在生成的exe文件運行時需要連同這個dll一起轉移,相比於一個單獨乾凈的exe,這種形式總歸讓人不爽,那麼有辦法讓生成的軟體中直接就包含這個dll文件嗎,這樣就可以不用dll跟著exe走了,避免單獨不能運行的 ...
  • 前幾天做項目用到了動軟代碼生成器 對剛出社會的我來說可以說什麼都不知道,對此趕緊學習了一下才發現這是李天平老師開發的軟體膜拜一下! 以此總結一下 1.軟體基本使用 我在百度下載的是V2.78版的 添加伺服器 選擇要連接的資料庫 點擊連接/測試 看是否成功,同時選擇要連接的資料庫,不然載入全部庫要等好 ...
  • 在學完了C#的方法和數據類型之後,寫了一個簡易的計算器的界面。本次界面具備加減乘除求餘等五項運算。不過存在一點缺陷就是無法判斷輸入數據的類型,是整數還是小數,由於目前所學知識有限,等學到以後再進行完善。 本設計源代碼如下: using System; using System.Collections ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...