Asp.net Core 2.0 OpenId Connect Handler缺失Claims?

来源:https://www.cnblogs.com/lookerblue/archive/2019/06/27/11098414.html
-Advertisement-
Play Games

原文:https://leastprivilege.com/2017/11/15/missing-claims-in-the-asp-net-core-2-openid-connect-handler/發佈於:2017年11月環境:ASP.NET Core 2.0 原文:https://leastp ...


 

原文:https://leastprivilege.com/2017/11/15/missing-claims-in-the-asp-net-core-2-openid-connect-handler/
發佈於:2017年11月
環境:ASP.NET Core 2.0

通過OIDC provider 把Claims映射到ClaimsPrincipal這一步驟,在ASP.NET Core 2中新的OpenID Connect handler具有不同的行為。
這是特別令人困惑和難以診斷的,因為這裡有幾個部件聚集在一起。我們來看一下。
您可以使用我的示例OIDC客戶端來觀察到相同的結果。

將標準claim類型映射到Microsoft專有claim類型

一件令人煩惱的事情是微軟仍然認為他們知道什麼是最適合你的,將OIDC標準聲明映射到其專有聲明。
可以通過清除Microsoft JWT令牌處理程式上的入站聲明類型映射來優雅地修複:

JwtSecurityTokenHandler.DefaultInboundClaimTypeMap.Clear();

基本的OpenId Connect授權請求

接下來,讓我們從客戶端請求openid scope的場景開始。
首先令人困惑的是Microsoft使用openid和profile scope預先在OpenIdConnectOptions上填充了Scope集合。這意味著如果你只想請求openid,你首先需要清除Scope集合,然後手動添加openid。

services.AddAuthentication(options =>
{
    options.DefaultScheme = "Cookies";
    options.DefaultChallengeScheme = "oidc";
})
    .AddCookie("Cookies", options =>
    {
        options.AccessDeniedPath = "/account/denied";
    })
    .AddOpenIdConnect("oidc", options =>
    {
        options.Authority = "https://demo.identityserver.io";
        options.ClientId = "server.hybrid";
        options.ClientSecret = "secret";
        options.ResponseType = "code id_token";
 
        options.SaveTokens = true;
                    
        options.Scope.Clear();
        options.Scope.Add("openid");
                    
        options.TokenValidationParameters = new TokenValidationParameters
        {
            NameClaimType = "name", 
            RoleClaimType = "role"
        };
    });

使用ASP.NET Core v1處理程式,將返回以下聲明:nbf,exp,iss,aud,nonce,iat,c_hash,sid,sub,auth_time,idp,amr。

在V2中我們只能得到sid,sub和idp。發生了什麼?

微軟在其OpenID Connect handler中添加了一個名為ClaimActions的新概念。Claim actions用來實現自外部provider的claim如何映射(或不)到您的ClaimsPrincipal中的claim。查看OpenIdConnectOptions的構造函數,您可以看到,處理程式現在預設會跳過以下聲明:

ClaimActions.DeleteClaim("nonce");
ClaimActions.DeleteClaim("aud");
ClaimActions.DeleteClaim("azp");
ClaimActions.DeleteClaim("acr");
ClaimActions.DeleteClaim("amr");
ClaimActions.DeleteClaim("iss");
ClaimActions.DeleteClaim("iat");
ClaimActions.DeleteClaim("nbf");
ClaimActions.DeleteClaim("exp");
ClaimActions.DeleteClaim("at_hash");
ClaimActions.DeleteClaim("c_hash");
ClaimActions.DeleteClaim("auth_time");
ClaimActions.DeleteClaim("ipaddr");
ClaimActions.DeleteClaim("platf");
ClaimActions.DeleteClaim("ver");

如果您想“取消”跳過某項聲明,則需要在設置handler時刪除特定聲明。以下是獲取amr聲明的非常直觀的語法:

options.ClaimActions.Remove("amr");

從OIDC provider請求更多的Claim

當你要求更多的範圍時,例如個人資料或自定義範圍導致更多索賠,還有另一個令人困惑的細節需要註意。
根據OIDC協議中的response_type,某些聲明通過id_token進行傳輸,有些通過userinfo端點進行傳輸。我在這裡寫了關於此細節的文章
因此,首先您需要在處理程式中啟用對userinfo端點的支持:

options.GetClaimsFromUserInfoEndpoint = true;

如果聲明由userinfo返回,ClaimsActions將用於從返回的JSON文檔映射claim到principal。這裡使用以下預設設置:

ClaimActions.MapUniqueJsonKey("sub", "sub");
ClaimActions.MapUniqueJsonKey("name", "name");
ClaimActions.MapUniqueJsonKey("given_name", "given_name");
ClaimActions.MapUniqueJsonKey("family_name", "family_name");
ClaimActions.MapUniqueJsonKey("profile", "profile");
ClaimActions.MapUniqueJsonKey("email", "email");

如果您向您的客戶發送的不屬於上述列表的claim,它會被忽略,您需要進行明確的映射。例如您希望客戶端通過userinfo(標準OIDC聲明之一,但不幸未由Microsoft映射)獲得website claim - 您需要自行添加映射:

options.ClaimActions.MapUniqueJsonKey("website", "website");

這同樣適用於您通過userinfo返回的任何其他聲明。

我希望這有幫助。簡而言之 – 你應該明確的知道你的映射,因為我相信這些預設映射將在可能會發生變化,這將導致您的客戶端應用程式出現意外行為。


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

-Advertisement-
Play Games
更多相關文章
  • JAVA-基礎(Class對象及反射) 1.(1)什麼是class對象? 首先,java有兩種對象,第一種是實例對象,第二種是Class對象,每一個類運行的類型信息就是用Class對象表示的,每一個對象都有一個到java.lang.Class(用於描述對象的結構)的實例的引用。Class類沒有公共的 ...
  • 小白程式猿,練練手,做做題目,分享下經驗, 有不對的,還請大家能夠指出,多多包涵!謝謝!! 先簡單,後複雜,循序漸進,希望能夠堅持下來, 大家一起進步~~ ...
  • 一、微服務概述 1. 什麼是微服務  簡單地說, 微服務是系統架構上的一種設計風格, 它的主旨是將一個原本獨立的系統拆分成多個小型服務,這些小型服務都在各自獨立的進程中運行,服務之間基於 RPC 進行通信協作。 被拆分成的每一個小型服務都圍繞著系統中的某一項或一些耦合度較高的業務功能進行構 ...
  • 1 import java.sql.Connection; 2 import java.sql.DriverManager; 3 import java.sql.ResultSet; 4 import java.sql.SQLException; 5 import java.sql.Statemen... ...
  • 傳遞任意數量的實參 形參前加一個 * ,Python會創建一個已形參為名的空元組,將所有收到的值都放到這個元組中: 不管函數收到多少實參,這種語法都管用。 1. 結合使用位置實參和任意數量實參 運行結果: 2. 使用任意數量的關鍵字實參 形參**user_info中的兩個星號讓python創建了一個 ...
  • 我們都知道.NET Core 3.0已經發佈了第六個預覽版,我們也知道.NET Core 3.0現在已經支持創建WPF項目了,剛好今天在寫一個代碼生成器的客戶端的時候用到了WPF,所以就把WPF創建以及使用IOC的過程記錄一下,希望能對大家有所幫助。當然文章實例我就以我曾閱讀過的一篇文章的示例代碼來 ...
  • 視圖組件 asp.net core mvc 提供了部分視圖的新替代品:視圖組件。 視圖組件與分佈視圖的主要區別在於視圖組件與控制器不相關。可使用在獨立於單個控制器的場景,如:菜單導航、側邊欄、分頁欄等。 在Shared文件夾中為視圖創建Components文件夾,再創建對應組件的OneModel文件 ...
  • 參考地址:https://blog.csdn.net/qq_18979049/article/details/78613878 一、情景描述 1.有的項目需要部署才能進行真實情況模擬(例如微信公眾號),但是怎麼樣在部署的情況進行調試,就是今天的主題了。 二、解決方案一 1.iis上添加網站,物理位置 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...