IdentityServer4 SigningCredential(RSA 證書加密)

来源:http://www.cnblogs.com/xishuai/archive/2017/06/05/identityserver4-signing-credential-rsa.html
-Advertisement-
Play Games

IdentityServer4 預設提供了兩種證書加密配置: 這兩種證書加密方式,都是臨時使用,每次重啟項目的時候,都會重新生成一個新的證書,這時候就會導致一個問題,重啟之前生成的 ,在重啟之後,就不適用了,因為證書改變了,對應的加密方式也改變了,所以,就會出現下麵這個問題: 錯誤信息: Www A ...


IdentityServer4 預設提供了兩種證書加密配置:

services.AddIdentityServer()
    .AddDeveloperSigningCredential()
    .AddTemporarySigningCredential();

這兩種證書加密方式,都是臨時使用,每次重啟項目的時候,都會重新生成一個新的證書,這時候就會導致一個問題,重啟之前生成的access_token,在重啟之後,就不適用了,因為證書改變了,對應的加密方式也改變了,所以,就會出現下麵這個問題:

錯誤信息:

Www-Authenticate:Bearer error="invalid_token", error_description="The signature key was not found"

解決方式,就是始終使用一個證書,我們先這樣配置:

services.AddIdentityServer()
    .AddDeveloperSigningCredential();

可以查看下AddDeveloperSigningCredential實現源碼,啟動項目,IdentityServer4 會在項目目錄中生成一個tempkey.rsa證書文件:

{
    "KeyId": "4e1765de45ef639261115198826dfea7",
    "Parameters": {
        "D": "FnB7kIinBgoZDaRqIrRQHEF45FBF9amOrTn8oFdmsxPqJbh11bHeCw11AtCCC4p1mm750onDXeP+yoBHymr/wNn40VmGdhR4hnObHhhw5pyQKECIS41DFDatCZif9uhDgHsOvYHMRVNSapDFoDUvbTE6t7rv4prn2fDt5mzRD9AqdT2HyTcwa/H1haaZNwmy3UevYYy8ya4kKXvjRo6+O7BMBh+yBvHgezQ57Ye/NfZfDMITs4djbqELrYVXCTMltNsWWhQtS62cqvKboxoiXfSm67u/li5Fdusc5Z2zsyt5rE/V8h/ffBvS9N9v0VoDTdFqLYkuul0DvTZ/pqXtMQ==",
        "DP": "XQDf46csbwu/xX+jwo5VQQ8sKVlVBLuxSNTAbNS6O/aCg9eEjZ58EJ712JgqqORcDMg5JRejN3Zxxoij4roJogyvvw6QSws/H+UTmtuuudgT59OB1TyNGihMVSTLXaw4Kgdj8D8IK8v0okdFEpYugzIIFe1yl0lSzR7fkF+NKC0=",
        "DQ": "4TvT9ujJ38sTluz0dUSIUD3NCWJOMDKOB/cL3RaDyMf/MTSxNFfWDuuW55F2P8mncHhqLuANcg2l3h8xom+1ucn+ve45JNoWja4fpWQ16rmijPc5yKRe0uAGEaXJiTAEvIxXG18zvNA8Fab+L2X1h+1r35ZLZFYj+EyhkqQ7u5k=",
        "Exponent": "AQAB",
        "InverseQ": "nTAEt8v+DlAn6h7Z1Ey1x4Z56OfOmCvY01nte4f3OuSmBXoEaTSoGsXScweAMoSGb0aOG1qpvErtY+JykREeLJxvm4P3DAHL5lJWvDKPvCWJOD9jfzhBUyIhCoqQ8EIHjFxBNKyNefAsVuKdH6R+ApuhpF8XVhR59zLawUQWLEg=",
        "Modulus": "43j4tvNZy7IxuiDwZzWv9KiS5kSYIeBqEvQ7zkQmRT3IEsseiTv698iQx8qn+de8FeGFEa8O6igFU2VXqFyWJilTuPmeBPJxIMCqfxdxF+96giVSpN4rOFaH/V+IPNTQoYCLFwcUR2saFywUeKWpsRFhQCymsFIk3AlWu7jcqgKHrELsJpn5KVmedb6JZcVKMIfTrcY6hWQz2JNEhTOEI10ZVZ7ueEp2Q2+1/udvp47wPMhzriXJTFP7Y4ozU2THbuwIqCXM5DNBGUpEug0vlCAhwn6nvAo8e9fT0lpUzTd2T8wWzwuHkAgyjB0XTzSYR1fMJIKH1zDs25RqmlepgQ==",
        "P": "9lGtQw9yXz4nbepESFDxAMfDlmiI9Gj3Q3FecKIgGVVi9WVr19lzBcszhsVybA8n1OyPXHdOyuSWOiVp69ibo5OOXLL4iWzY1VOouXeZrYimxNPvVKlRf8AsVcv3n/0/FEhwY9gnQm4PZYUGwQ96WZ5Z/CWJ9xTORg54Wh79hk0=",
        "Q": "7Gmr/h33bM+9W4Ygh+tNh3/etECuT/RQ1LMS5uBXxXdvUl6wSm2+ec/CBRobxVHG2pDXdr0pegn0Yz4MprsLtS5KvFg6yopI3Y3TptTGNZPtbd1O7P4i6b+RNOYCq0Y99mkGofqAlAMnDG+SA2EJN2ugPjLelC7GWtfzNG5NMgU="
    }
}

AddDeveloperSigningCredential中代碼執行,會先判斷tempkey.rsa證書文件是否存在,如果不存在的話,就創建一個新的tempkey.rsa證書文件,如果存在的話,就使用此證書文件。

所以,我們配置的時候,傳遞一個tempkey.rsa證書文件名,就可以了:

services.AddIdentityServer()
    .AddDeveloperSigningCredential("tempkey.rsa");

當然,你也可以對tempkey.rsa證書文件,進行重命名操作。

參考資料:


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

-Advertisement-
Play Games
更多相關文章
  • SQL 語句中In 和 Where 的含義不同。應用解釋如下:1、如需有條件地從表中選取、刪除、更新數據時,使用Where;2、In只作為Where條件子句下的一個運算符,除了In之外還有Between、Like、=、>、>=、<、<=等運算符。下麵舉例說明:1、查詢名字為A和B的學生,則語句為Se ...
  • 我們時長在批量插入時,需要獲取插入數據的id. 這樣: 這樣是沒問題的. 但是有時候牽扯到批量插入,並且獲取插入的id 這樣寫: 這樣運行後就會出現異常了. 這是因為你用的mybatis版本過低.比如我用的是3.2.2版本,這是mybatis的一個bug. 如果你換成3.4.4版本就沒有問題了. 上 ...
  • 一、變數 1.變數的命名規則:以字母或下劃線開頭,後面跟數字,字母或下劃線,最好不要隨便命名,要做到看見變數名能猜出其含義 2.變數賦值: x=100 echo $x 刪除變數:unset x 3.定義變數名的邊界用大括弧 [root@bogon ~]# egon_salary=20000[root ...
  • linux下部署php項目環境可以分為兩種,一種使用Apache,php,mysql的壓縮包安裝,一種用yum命令進行安裝。 使用三種軟體的壓縮包進行安裝,需要手動配置三者之間的關係。apache和php之間的配置沒有什麼難度,但是和mysql進行配置的時候就需要對php的瞭解了。 以下是用yum在 ...
  • 聲明:本文為轉載內容,感謝原作者辛勤勞動。原鏈接為:http://www.cnblogs.com/chinahbzm/articles/1423875.html 1)建立空連接: net use \\IP\ipc$ "" /user:"" (一定要註意:這一行命令中包含了3個空格) 2)建立非空連接 ...
  • 引言 最新有一個winform項目使用的是DevExpress的控制項,所以最近都在摸索使用這套控制項,實在是佩服整套控制項的強大,同時代碼寫起來也簡潔。客戶有一個需求,希望報表結果能在外接的大屏幕上定時滾動。這個報表我們使用的控制項就是GridControl,查詢結果一屏不能顯示完全,增加一個定時器,指定 ...
  • 什麼是AspectCore Project ? "AspectCore Project" 是適用於Asp.Net Core 平臺的輕量級 Aop(Aspect oriented programming) 解決方案,它更好的遵循Asp.Net Core的模塊化開發理念,使用AspectCore可以更容 ...
  • 一:安裝 運行項目後,進去安裝頁面,按照提示輸入,填寫的管理員郵箱和密碼,即超管的賬號,登陸後,頂部會有後臺鏈接。 二:無法進入後臺 解決辦法:生成下解決方案就好了。 三:首頁Banner在哪改? 進入後臺,Configuration -> Widgets -> Widgets.NivoSlider ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...