主頁 > .NET開發 > OAuth2、OpenID Connect簡介

OAuth2、OpenID Connect簡介

2020-09-23 15:41:15 .NET開發

當我們在登錄一些網站的時候,需要第三方的登錄,比如,現在我們要登錄簡書https://www.jianshu.com/sign_in,我們使用微博登錄,點擊下方的一個微博的小按鈕,就會出現這么一個地址https://api.weibo.com/oauth2/authorize?client_id=1881139527&redirect_uri=http%3A%2F%2Fwww.jianshu.com%2Fusers%2Fauth%2Fweibo%2Fcallback&response_type=code&state=%257B%257D,乍一看,這是什么玩意啊,我們來分解下:

https://api.weibo.com/oauth2/authorize?
client_id=1881139527&
redirect_uri=http%3A%2F%2Fwww.jianshu.com%2Fusers%2Fauth%2Fweibo%2Fcallback&
response_type=code&
state=%257B%257D

現在就要引出今天的主角了,OAuth2

那什么是OAuth2呢?

https://oauth.net/2/這是官網

https://open.weibo.com/wiki/授權機制,這是微博的授權機制

http://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html,這是阮一峰寫的一篇對于OAuth2的介紹,

OAuth2.0是一個委托協議,它可用讓那些控制資源的人允許某個應用代表這些人,而不是假冒和模仿這喜人,這個應用從資源的所有者哪里得到授權(Authorization)和Access Token,隨后就可以使用這個Access Token來訪問資源,(這里提到的假冒和模仿就是指在客戶端復制一份用戶名和密碼,從而獲取回應的權限),是關于授權(Authorization)的,客戶端應用可以請求Access Token,使用Tooken就可以訪問API資源了,在上述的例子中,是微博給簡書授權,

讓客戶端應用可以代表資源所有者(通常是用戶)來訪問被保護的資源,如下圖:

 

 

 資源所有者(Resource Owner),他擁有訪問API資源的權限,并且他還可以委派權限(delegate)給其他應用來訪問API,資源所有者通常是可以使用瀏覽器的人,

被保護的資源(Protected Resource)就是資源所有者擁有權限去訪問的組件,它可以是很多種形式的,但是WebApi的形式還是最常見的,

客戶端(Client)應用就是代表資源所有者訪問被保護資源的一個軟體,注意它既不是瀏覽器,也不是給你錢讓你開發軟體的人,在OAuth2里面,它是指被保護的API資源的消費者,

授權服務器(AS)是被受保護的資源所信任的,它可以發行具有特定目的的安全憑據給客戶端應用,這個憑據就叫做OAuth的Access Token,

 

 

 授權,如下圖

 

 

 授權種類:

  1、Authorization Code

  2、Implicit

  3、Resource Owner Password Credentials,直接使用密碼憑據(用戶名和密碼)作為授權來獲得Access Token,只有當資源所有者和客戶端之間高度新人的時候并且其它授權方式不可用的時候才可以使用這種授權方式,

  4、Client Credentials,有時候,資源或者叫資源服務器,并不屬于某個最終用戶,也就是沒有資源所有者對該資源負責,但是客戶端應用肯定還是要訪問這些資源,這時候就只能使用Client Credentials這種授權方式了,

其他重要角色和組件:

  1、資源所有者Resource Owner  

  2、客戶端Client

  3、被保護資源 Protected Resource

  4、授權服務器Authorization Server

  5、Access Token,它是用來訪問被保護資源的憑據,授權服務器只是方形Token,被保護資源驗證Token,客戶端隊友Access Token應該是完全健忘的,

  6、Scopes,被保護資源那里的一套權限,具有疊加性

  7、Refresh Token,用來獲得Access Token的憑據,客戶端是用Refresh Token來請求信的Access Token

通過refresh token來取得新的access token的流程

 

 

 

 

 

 重要端點:

  1、授權端點(Authorization Endpoint)是用來和資源所有者互動的,資源所有者在這里進行登錄(身份認證),然后通過該端點可以對客戶端進行授權( Authorization  Grant),授權服務器首先要驗證資源所有者的身份,但是驗證的方式并不在OAuth2的協議范圍內,

  2、Token端點(Token Endpoint),客戶端通過向Token端點展示它的授權(Authorization Grant)或Refresh Token來獲取Access Token,除了Implicit之外所有的授權型別都需要使用該端點,因為Implicit和Access Token是直接發行的,

OpenId Connect(OIDC)

身份認證和授權,OAuth2不是身份認證(Authentication)協議,OpenId Connect可以進行身份認證(Authentication),

一個比喻,授權,就好比生牛奶(多用途原料);身份認證,就好比奶茶(一個最終產品),以牛奶為主原料,OAuth2,是生牛奶,眾多web安全架構的一種多用途的基本成分,OIDC,好比奶茶,基于OAuth2的身份認證協議,添加了一些組件來提供身份認證的能力,

更高級的協議,擴展并代替了OAuth2,OpenID Connect是建立在OAuth2協議上的一個簡單的身份標識層,所以OpenID Connect兼容OAuth2,使用OpenID Connect,客戶端應用可以請求Identity Token,它會和Access Token一同回傳給客戶端應用,這個Identity Token就可以被用來登錄客戶端應用程式,而客戶端應用還可以使用Access Token來訪問API資源,UserInfo端點,(OAuth2定義了Authorization端點和Token端點)它允許客戶端應用和獲取用戶的額外資訊,定義了不同型別的應用如何從身份識別提供商(IDP)安全的獲取到這些Token,

與OAuth 2.0之間的角色映射關系

  1、身份供應商(Identity Provider,IdP)

  2、依賴方(Relying Party,RP,可以理解Wie客戶端)

  3、OAuth2里面可以分為兩部分

    a、資源所有者/客戶端應用

    b、授權服務器/被保護資源

  4、身份認證協議里也是兩大不分

    a、依賴方

    b、身份提供商

  5、映射OAuth2------OIDC

   授權服務器/被保護資源------身份提供商進行映射

   資源所有者--------最終用戶

   客戶端應用-----依賴方(RP)

Auth 2.0 與 OIDC 角色映射

 

 

 抽象流程:

 

 

 依賴方(RP)發送請求到OpenID提供商(OP,也就是身份提供商),

OpenID提供商驗證最終用戶的身份,并獲得了用戶委派的授權

OpenID提供商回傳回應,里面呆著ID Token,也通常帶著Access Token

依賴方現在可以使用Access Token發送請求到用戶資訊的端點

用戶資訊端點回傳用戶的宣告(claims,相當于是用戶的資訊),

OpenId Connect身份認證流程

Authorization Code Flow: 

  在Authorization Code流程里,一個授權碼(Authorization Code)會被回傳給客戶端,這個授權碼可以被直接用來交換ID Token和Access Token,該流程也可以在客戶端使用授權碼兌換Access Token之前對其身份認證,但是該流程要求客戶端的身份認證動作在后臺使用Client 和Secret來獲得Tokens,這樣就不會把Tokens暴露給瀏覽器或者其他訪問瀏覽器的惡意應用了,

  要求客戶端應用可以安全的在它和授權服務器之間維護客戶端的Secret,也就是說只適合這樣的客戶端應用,它還適合于長時間的訪問(通過Refresh Token),授權碼來自于授權端點,而所有的Tokens都來自于Token端點,

  Authorization Code流程的步驟如下:

    客戶端準備身份認證請求,請求里包含所需要的引數

    客戶端發送請求到授權服務器

    授權服務器對最紅用戶進行身份認證

    授權服務得最終用戶的統一/授權

    授權服務器把最終用戶發送回客戶端,同時帶著授權碼

    客戶端使用授權碼向Token端點請求一個回應

    客戶端接收到回應,回應的Body里面包含在和ID Token和Access Token

    客戶端驗證ID Token,并獲得用戶的一些身份資訊

Implicit Flow:

  Implicit在請求Token的時候不需要明確的客戶端身份認證,它使用重定向URI的方式來驗證客戶端的身份,因為這一點,Refresh Token也就無法使用了,這同樣也不適合于長時間有效的Access Token,

  所有的Tokens都來自于授權端點,而Token端點并沒有用到,

  該流程主要用于瀏覽器內的應用,Access Token和ID To恩一同被直接回傳給客戶端,因為這個原因,這些Tokens也會暴露于最終用戶和跨域訪問該瀏覽器的其他應用了,它并不適合于長時間的訪問,

  Implicit流程的步驟如下:

    客戶端準備身份認證請求,請求里包含所需要的引數

    客戶端發送請求到授權服務器

    授權服務器對最終用戶進行身份認證

    授權服務器獲得最終用戶的同意/授權

    授權服務器把最終用戶發送客戶端,同事帶著ID Token,如果也請求了Access Token的話,那么Access Token也會一同回傳,

    客戶端驗證ID Token,并獲得用戶的一些身份資訊,

Hybrid Flow:

  Hybrid Flow是前兩者的混合,在該流程里,有一些Tokens和授權碼來自于授權重點,而另外一些Tokens則來自于Token端點,該流程允許客戶端立即使用ID Token,并且只需要一次往返即可獲得授權碼,這種流程也要求客戶端應用可以安全的維護Secret,它也適合于長時間的訪問,

  Hybrid Flow的步驟如下:

    客戶端準備身份認證請求,請求里包含所需要的引數

    客戶端發送請求到授權服務器

    授權服務器對最終用戶進行身份認證

    授權服務器獲得最終用戶的統一/授權

    授權服務器把最終用戶發送回客戶端,同事帶著授權碼,根據回應型別的不同,也考嫩惡搞帶著一個躲著多個其他的引數

    客戶端使用授權碼向Token端點請求一個回應

    客戶端接收到回應,回應的body里面包含著ID Token和Access Token

    客戶端驗證ID Token,并獲得用戶的一些身份資訊,

三種流程特點的比較

 

 

 回傳值型別的比較

 

 

 三種型別,根據response_type的不同,分為:

  response_type=code id_token、response_type=code token、response_type=code id_token token,

  注意:為了表明是OpenID Connect協議的請求,scope引數里必須包含OpenID,

esponse_type=code id_token

 

 

response_type=code token

 

 

response_type=code id_token token

 

Identity Server:

建立Identity Provider專案

dentityServer4.Templateshttps://github.com/IdentityServer/IdentityServer4.Templates

安裝工具:

dotnet new -i identityserver4.templates

重置 “dotnet new” 功能串列: dotnet new --debug:reinit

模板:

dotnet new is4empty、 dotnet new is4ui 、dotnet new is4inmem 、dotnet new is4aspid、 dotnet new is4ef 、dotnet new is4admin (收費)

 

使用Identity Server 建立Authorization Server:https://www.cnblogs.com/cgzl/p/7780559.html 

 

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/112688.html

標籤:.NET Core

上一篇:[AspNetCore 3.0] 在RazorPages/MVC 中使用 Blazor (Razor組件)

下一篇:ABP入門教程0 - 目錄

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • C#多執行緒學習(二) 如何操縱一個執行緒

    <a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...

    uj5u.com 2023-04-19 09:17:20 more
  • C#多執行緒學習(二) 如何操縱一個執行緒

    C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......

    uj5u.com 2023-04-19 09:16:49 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    <a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...

    uj5u.com 2023-04-18 08:39:04 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......

    uj5u.com 2023-04-18 08:33:10 more
  • SignalR, No Connection with that ID,IIS

    <a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...

    uj5u.com 2023-03-30 17:21:52 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:15:33 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:13:31 more
  • C#遍歷指定檔案夾中所有檔案的3種方法

    <a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...

    uj5u.com 2023-03-27 14:46:55 more
  • C#/VB.NET:如何將PDF轉為PDF/A

    <a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...

    uj5u.com 2023-03-27 14:46:35 more
  • 武裝你的WEBAPI-OData聚合查詢

    <a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...

    uj5u.com 2023-03-27 14:46:16 more