IdentityServer4 中文文檔 -1- (簡介)背景

来源:http://www.cnblogs.com/ideck/archive/2017/07/30/ids_intro_1.html
-Advertisement-
Play Games

IdentityServer4 是一個提供 認證服務,單點登錄/登出(SSO),API訪問控制,聯合認證通道的可定製、免費商業支持的框架。 ...


IdentityServer4 中文文檔 -1- (簡介)背景

原文:http://docs.identityserver.io/en/release/intro/big_picture.html

下一篇:IdentityServer4 中文文檔 -2- (簡介)相關術語

現代應用程式看上去大都是這樣的:

常見的交互方式包括:

  • 瀏覽器 與 Web應用程式 通信;
  • Web應用程式 與 Web API 通信(Web應用程式自身 或 代表用戶 與 Web API 通信);
  • 基於瀏覽器的應用程式 與 Web API 通信;
  • 本地應用程式 與 Web API 通信;
  • 基於伺服器的應用程式 與 Web API 通信;
  • Web API 與 Web API 通信(WebAPI自身 或 代表用戶與另一個WebAPI 通信);

將基礎安全功能外包給一個安全令牌服務(STS,Security Token Service),能夠避免這些應用程式以及端點之間的功能性重覆。

重組應用程式以支持一個安全令牌服務,能夠導出以下架構和協議:

這樣的設計把安全問題分成了兩個部分:

身份認證

當一個應用程式需要知道當前用戶的身份(Identity)的時候就要用到身份認證(Authentication)。通常情況下這些應用程式托管著代表該用戶的數據,並且必須確保該用戶只能訪問被允許訪問的數據。最常見的例子就是傳統的web應用程式 —— 但是本地應用程式和基於JS的應用程式也同樣需要身份認證。

最常見的身份認證協議是 SAML2p、WS-Federation 和 OpenID Connect——SAML2p 是最受歡迎的,也是部署得最廣泛的。

OpenID Connect 是三種協議中最新的一種,但它卻被認為是未來的趨勢,因為它對於現代應用程式來說最具潛力。它從一開始就是為移動應用場景而構建的,並且被設計成了友好的API。

API訪問

應用程式有兩種基礎的方式與API通信 —— 使用應用程式身份,或者使用代表用戶的身份。有時候需要聯合使用這兩種方式。

OAuth2 是一個通信協議,它允許應用程式向安全令牌服務請求訪問令牌,然後通過訪問令牌與API通信。這同時減少了客戶應用程式和API的複雜性,因為認證和授權可以是集中式的。

OpenID Connect和OAuth2 —— 結合使用更好

OpenID Connect和OAuth2非常相似 —— 實際上前者是後者的頂級擴展。它們把兩個基礎安全問題(身份認證和 API 訪問)合併成了一個單一的協議 —— 通常這隻是與安全令牌服務的一個往返交互。

我們堅信,將 OpenID Connect 和 OAuth2 結合以保護現代應用程式,在可預見的未來,肯定會是最佳實踐。IdentityServer4 是這兩種協議的實現,並且它已經被高度優化以解決當今 移動應用程式、本地應用程式 和 Web應用程式 的典型安全問題。

IdentityServer4 能做什麼?

IdentityServer4 是一個中間件 ,它能夠將符合規範的 OpenID Connect 和 OAuth2.0 端點添加到任意一個 ASP.NET Core 應用程式中。

通常,在你構建(或者復用)一個包含登錄和註銷頁(或者 授權確認頁)的應用程式的時候,IdentityServer 中間件會將需要的協議添加到頁面頭部,這樣一來客戶端應用程式就能夠使用這些標準協議跟它協商了。

你可以根據你的需要使用儘可能複雜的宿主應用程式。但是,為了保持受攻擊面儘可能小, 我們一般建議你只將認證相關的UI包含進來。

下一篇:IdentityServer4 中文文檔 -2- (簡介)相關術語


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

-Advertisement-
Play Games
更多相關文章
  • 最近工作中老是遇到 button的MouseLeftButtonDown事件不觸發的現象 然後就用了MouseLeftButtonUp事件 或者是隧道事件 就解決了不觸發了問題 然後網上也有人 建議是重寫MouseLeftButtonDown的事件 修改那個Handled 屬性 自己試了一下 真的很 ...
  • 首先看測試代碼: 1 public class StringSpeedTest 2 { 3 private readonly static string _testStr = "0123456789"; 4 5 public string StringAdd(int count) 6 { 7 str ...
  • 原文:https://www.stevejgordon.co.uk/asp-net-core-mvc-anatomy-addmvccore發佈於:2017年3月環境:ASP.NET Core 1.1 歡迎閱讀新系列的第一部分,我將剖析MVC源代碼,給大家展示隱藏在錶面之下的工作機制。此系列將分析MV ...
  • 1.什麼是委托? 1.1委托是一種引用類型,該類型適用於將方法用特定的簽名封裝,我們可以將委托理解為一個封裝了函數指針和方法的特殊類型。 1.2使用委托我們可以將方法封裝在委托中,然後調用委托就可以調用其中的方法 2.委托的基本聲明格式 修飾符 delegate 返回類型 委托名(參數列表)——返回 ...
  • 前面講了 "文件的上傳" ,今天來聊聊文件的下載。 老規矩,還是從最簡單粗暴的開始。那麼多簡單算簡單?多粗暴算粗暴?我告訴你可以不寫一句代碼,你信嗎?直接把一個文件往IIS伺服器上一扔,就支持下載。還TM麽可以斷點續傳(IIS服務端預設支持)。 在貼代碼之前先來瞭解下什麼是斷點續傳( 這裡說的是下載 ...
  • IdentityServer4 是一個提供 認證服務,單點登錄/登出(SSO),API訪問控制,聯合認證通道的可定製、免費商業支持的框架。 ...
  • IdentityServer4 是一個提供 認證服務,單點登錄/登出(SSO),API訪問控制,聯合認證通道的可定製、免費商業支持的框架。 ...
  • IdentityServer4 是一個提供 認證服務,單點登錄/登出(SSO),API訪問控制,聯合認證通道的可定製、免費商業支持的框架。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...