OAuth2.0 在 SSO中的應用~

来源:http://www.cnblogs.com/jackicalSong/archive/2016/03/21/5301752.html
-Advertisement-
Play Games

oauth2.0 sso jackical


關於OAuth2.0的介紹,請看下麵鏈接(講的挺好的):

http://blog.csdn.net/seccloud/article/details/8192707

我的理解:

一共四個角色,A:Client(訪問者),B:資源擁有者,C:許可權控制平臺,D:資源中心

訪問流程:Client(訪問者)向 資源擁有者索要 資源訪問許可權, 資源擁有者 給 Client(訪問者)開個授權書,Client(訪問者)拿著授權書到  許可權控制平臺 索要訪問令牌,Client(訪問者)獲取令牌,憑令牌訪問資源

打個不恰當比法:C 欠 A 一筆錢,A沒時間去向C 討債,於是A給B開個委托書讓B去拿錢,C 看了委托書確認了A確實委托了B,也確認了B的身份,於是C給了B一把保險柜的鑰匙,讓B 自己去取錢。

以上兩個例子,相信你己瞭解什麼是OAuth2.0了吧。

 

關於SSO 理解

去年看了博客園某大神的大作之後,記下了筆記沒留URL,現就對著筆記進行回顧下。

客人訪問A站點,需要登錄,於是跳轉到SSO進入登錄,backurl帶上A站點的URL,當登錄成功之後,跳回A站點,並給SSO的憑證與A站點的憑證。

客人從A站點跳轉到B站點,B站點需要驗證客人的身份,帶上SSO的憑證到SSO進入驗證,通過之後,給B站點發B站點的憑證。

一個邏輯:接入站點先判斷是否有SSO的憑證,有則判斷是否有接入站點憑證。若沒有SSO的憑證,有接入站點憑證需重新登錄。若有SSO的憑證,沒有接入站點憑證,從SSO站點獲取接入站點憑證。

 

現在的問題是怎麼將這兩者結合一起成為一個系統?!

OK大片來了,以下將模擬騰訊開放平臺中的QQ授權登錄(以下內容僅個人結合oauth2.0與sso業務邏輯想象出來,還未驗證)。   現有兩個子站點如A.com ,B.com ,還有個是統一登錄平臺(sso.com)   首先接入站點需要從sso.com中獲取私鑰,指定一個notify頁面。 1,客人client訪問A.com ,需要登錄A.com網站,跳轉到sso.com指定頁面(如:/login),帶上redirect_url就是a.com的URL。 2,在這個登錄頁上輸入帳號及密碼登錄成功之後,sso.com 會向a.com  之前提交的nofity頁面回發用戶的票據及state(公鑰)。 3,a.com  的notify頁面接受到票據與公鑰之後,將自己的私鑰與公鑰 按照簡單的演算法處理下,再MD5之後,一起發回 sso.com,sso.com拿到a.com的身份信息之後確認正確,再將Token發給a.com。 4,sso.com發送token之後,再跳轉回a.com的頁面(redirect_url)。     根據我的設想與實際操作騰訊單點登錄, 登錄成功之後,會有較長時間在那等待,就是在完成,發送票據、驗證client身份、下發token 的過程。     【轉載請標註,From http://www.cnblogs.com/jackicalSong/】  以上邏輯未進行生產驗證,僅一個思路,後期有時間,我會驗證下。      
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • scala是一種函數式編程風格的語言,除了常見的if......else ,for ,while等傳統的流程式控制制結構,也可以自定義流程式控制制的控制結構。 再瞭解scala如何實現編寫新的流程結構,我們瞭解一下頭等函數的概念; scala的函數是頭等函數(first-class function).你不
  • 輸出為1
  • 一、順序結構(從上往下依次執行) 順序結構語法比較簡單,從上往下依次執行即可。 二、選擇結構(選擇性執行,如果....則.....) 1.if 語句 if語句,作用是根據判斷結果為真或假,選擇其中一個分支執行。 if (條件判斷,結果為布爾值){ 條件判斷為真時的執行語句(只能是一句語句,如果是多句
  • 迭代器模式,在不需要瞭解內部實現的前提下,遍歷一個聚合對象的內部元素。相比於傳統的編程模式,迭代器模式可以隱藏遍歷元素所需要的操作。 AllHacl.php index.php Hacl類相關內容參考數據對象映射模式。http://www.cnblogs.com/tianxintian22/p/52
  • (一)變數的命名及賦值: var=value (1)、其中var是變數名,value是變數的值。如果value不包含任何空白字元(空格),就不需要包含單引號或雙引號 (2)、var=value不同於var (空格)=(空格)value,前者是賦值操作,後者是相等操作 (3)、在變數名前加$或者$(v
  • 本實驗主要是實現蜂鳴器的操作,蜂鳴器的操作是非常簡單的,只有把簡單的事情做好,方可談其他複雜的事。本實驗部分會利用verilog一些巨集定義語句,其實在VGA實驗部分已經出現過,這裡為了鞏固,再次調用相關巨集定義命令,已達到最大化的可移植性,請讀者務必掌握這種用法,很實用。 談及蜂鳴器或者LED,多多少
  • 這幾天呢,公司風波再起,去年一年公司CTO換啦4任,CEO換啦三個,這不剛來個新老大,感覺還不錯,卻沒乾過3個月又要走,索性趁老大們走來走去的時候,就給自己空出來,稍稍總結一下剛寫的一個日誌服務組件中用到的RabbitMQ,在.net中的實戰中應用。 首先不去討論我的日誌組件怎麼樣。因為有些日誌需要
  • 少爺菜鳥一枚,求輕噴。 今天在網上無意間看到一道面試題,感覺挺有意思的,題目是這樣:"請用任意一種面向對象語言實現一個電腦控制台程式,要求輸入兩個數和運算符號,輸出結果”。 第一遍的時候還在想,居然還有這麼簡單的面試題?花了幾分鐘敲了一下這個程式,代碼如下(為了方便,代碼本身不規範,很多情況並未考
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...