IdentityServer4 實現自定義 GrantType 授權模式

来源:http://www.cnblogs.com/xishuai/archive/2017/06/26/identityserver4-implement-custom-granttype.html
-Advertisement-
Play Games

OAuth 2.0 預設四種授權模式(GrantType): 授權碼模式( ) 簡化模式( ) 密碼模式( ) 客戶端模式( ) 使用 IdentityServer4,我們可以自定義授權模式嗎?答案是可以的,比如我們自定義實現一個 授權模式(匿名訪問)。 創建 (繼承 ): 修改 配置: DI 增加 ...


OAuth 2.0 預設四種授權模式(GrantType):

  • 授權碼模式(authorization_code
  • 簡化模式(implicit
  • 密碼模式(password
  • 客戶端模式(client_credentials

使用 IdentityServer4,我們可以自定義授權模式嗎?答案是可以的,比如我們自定義實現一個anonymous授權模式(匿名訪問)。

創建AnonymousGrantValidator(繼承IExtensionGrantValidator):

public class AnonymousGrantValidator : IExtensionGrantValidator
{
    private readonly ITokenValidator _validator;

    public AnonymousGrantValidator(ITokenValidator validator)
    {
        _validator = validator;
    }

    public string GrantType => "anonymous";

    public async Task ValidateAsync(ExtensionGrantValidationContext context)
    {
        //var userToken = context.Request.Raw.Get("token");

        //if (string.IsNullOrEmpty(userToken))
        //{
        //    context.Result = new GrantValidationResult(TokenRequestErrors.InvalidGrant);
        //    return;
        //}

        //var result = await _validator.ValidateAccessTokenAsync(userToken);
        //if (result.IsError)
        //{
        //    context.Result = new GrantValidationResult(TokenRequestErrors.InvalidGrant);
        //    return;
        //}

        // get user's identity
        //var sub = result.Claims.FirstOrDefault(c => c.Type == "sub").Value;

        var claims = new List<Claim>() { new Claim("role", GrantType) }; // Claim 用於配置服務站點 [Authorize("anonymous")]
        context.Result = new GrantValidationResult(GrantType, GrantType, claims);
    }
}

修改Client配置:

new Client
{
    ClientId = "client1",
    AllowedGrantTypes = GrantTypes.List(GrantTypes.ResourceOwnerPassword.FirstOrDefault(), "anonymous"), //一個 Client 可以配置多個 GrantType
    AllowOfflineAccess = true,
    AccessTokenLifetime = 3600 * 6, //6小時
    SlidingRefreshTokenLifetime = 1296000, //15天
    ClientSecrets =
    {
        new Secret("123".Sha256())
    },
    AllowedScopes = new List<string>
    {
        "api2"
    }
}

DI 增加註入對象:

builder.AddExtensionGrantValidator<AnonymousGrantValidator>();

調用示例代碼:

public async Task<TokenResponse> AnonymousAsync(string userToken)
{
    var payload = new
    {
        token = userToken
    };

    // create token client
    var client = new TokenClient(disco.TokenEndpoint, "client1", "123");

    // send custom grant to token endpoint, return response
    return await client.RequestCustomGrantAsync("anonymous", "api2", payload);
}

Http 訪問示例:

POST /connect/token

grant_type=anonymous&
scope=api2&
token=...&
client_id=api1.client
client_secret=secret

參考資料:


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

-Advertisement-
Play Games
更多相關文章
  • using System.Web; using System.Configuration; namespace DotNet.Utilities { public class VideoConvert : System.Web.UI.Page { public VideoConvert() { } ...
  • 1.Model 2.cotroller 3.View ...
  • 可進行FTP的上傳,下載等其他功能,支持斷點續傳: using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Net; using System.Text; usi ...
  • 1.Model 2.controller (1)先寫一個程式綁定,可以通過資料庫綁定或者直接綁定 (2)初始化,並傳給視圖 3.視圖 ...
  • 下圖為一個已經創建好的資料庫表關係 實體數據模型的創建過程 在Visual Studio項目中,右鍵程式集菜單,選擇【添加】 》【新建項】,在【添加新項視窗】中選擇【ADO.NET實體數據模型】,如下圖 在【實體數據模型嚮導】視窗中選擇【來自資料庫的EF設計器】 然後選擇資料庫連接,如果沒有的話,可 ...
  • 2017 06 28 更新: OptionsSnapshot 已改為 OptionsManager "變更詳情" IOptionsCache 已改為 IOptionsMonitorCache "變更詳情" 在 "上一章" 中,介紹了 IOptions 的使用, 而我們知道,在 Configurati ...
  • 一、簡介 眾所周知,值類型變數不能null,這也是為什麼它們被稱為值類型。但是,在實際的開發過程中,也需要值為null的一些場景。例如以下場景: 場景1:您從資料庫表中檢索可空的整數數據列,資料庫中的null值沒有辦法將此值分配給C#中Int32類型; 場景2:您在UI綁定屬性,但是某些值類型的欄位 ...
  • 一、WCF服務端應用程式 1、創建WCF服務端應用程式項目 打開Visual Studio 2013,在菜單上點擊文件—>新建—>項目—>WCF服務應用程式。在彈出界面的“名稱”對應的文本框中輸入“WcfService”,然後點 擊“確定”按鈕。如下圖。 2、安裝Entity Framework 1 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...