欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一個注解搞定Spring Security基于Oauth2的SSO單點登錄功能

 更新時間:2021年09月28日 09:00:26   作者:zlt2000  
本文主要介紹 同域 和 跨域 兩種不同場景單點登錄的實現(xiàn)原理,并使用 Spring Security 來實現(xiàn)一個最簡單的跨域 SSO客戶端。對Spring Security基于Oauth2的SSO單點登錄功能感興趣的朋友一起看看吧

一、說明

單點登錄顧名思義就是在多個應用系統(tǒng)中,只需要登錄一次,就可以訪問其他相互信任的應用系統(tǒng),免除多次登錄的煩惱。本文主要介紹 同域跨域 兩種不同場景單點登錄的實現(xiàn)原理,并使用 Spring Security 來實現(xiàn)一個最簡單的跨域 SSO客戶端 。

二、原理說明

單點登錄主流都是基于共享 cookie 來實現(xiàn)的,下面分別介紹 同域跨域 下的兩種場景具體怎樣實現(xiàn)共享 cookie

2.1. 同域單點登錄

適用場景:都是企業(yè)自己的系統(tǒng),所有系統(tǒng)都使用同一個一級域名通過不同的二級域名來區(qū)分。

舉個例子:公司有一個一級域名為 zlt.com ,我們有三個系統(tǒng)分別是:門戶系統(tǒng)(sso.zlt.com)、應用1(app1.zlt.com)和應用2(app2.zlt.com),需要實現(xiàn)系統(tǒng)之間的單點登錄,實現(xiàn)架構(gòu)如下:

核心原理:

  • 門戶系統(tǒng)設置 Cookiedomain 為一級域名也就是 zlt.com,這樣就可以共享門戶的 Cookie 給所有的使用該域名(xxx.zlt.com)的系統(tǒng)
  • 使用 Spring Session 等技術讓所有系統(tǒng)共享 Session
  • 這樣只要門戶系統(tǒng)登錄之后無論跳轉(zhuǎn)應用1或者應用2,都能通過門戶 Cookie 中的 sessionId 讀取到 Session 中的登錄信息實現(xiàn)單點登錄

2.2. 跨域單點登錄

單點登錄之間的系統(tǒng)域名不一樣,例如第三方系統(tǒng)。由于域名不一樣不能共享 Cookie 了,這樣就需要通過一個單獨的授權(quán)服務(UAA)來做統(tǒng)一登錄,并基于共享UAA的 Cookie 來實現(xiàn)單點登錄。

舉個例子:有兩個系統(tǒng)分別是:應用1(webApp.com)和應用2(zlt.com)需要實現(xiàn)單點登錄,另外有一個UAA授權(quán)中心(sso.com),實現(xiàn)架構(gòu)如下:

核心原理:

  • 訪問系統(tǒng)1判斷未登錄,則跳轉(zhuǎn)到UAA系統(tǒng)請求授權(quán)
  • 在UAA系統(tǒng)域名 sso.com 下的登錄地址中輸入用戶名/密碼完成
  • 登錄登錄成功后UAA系統(tǒng)把登錄信息保存到 Session 中,并在瀏覽器寫入域為 sso.comCookie
  • 訪問系統(tǒng)2判斷未登錄,則跳轉(zhuǎn)到UAA系統(tǒng)請求授權(quán)
  • 由于是跳轉(zhuǎn)到UAA系統(tǒng)的域名 sso.com 下,所以能通過瀏覽器中UAA的 Cookie 讀取到 Session 中之前的登錄信息完成單點登錄

2.3. 基于Oauth2的跨域單點登錄流程

關于Oauth2的授權(quán)碼模式這里就不做介紹了,自行找資料了解

三、Spring Security實現(xiàn)

Oauth2單點登錄除了需要授權(quán)中心完成統(tǒng)一登錄/授權(quán)邏輯之外

基于 Spring Security 實現(xiàn)的UUA統(tǒng)一授權(quán)中心可以參考:https://gitee.com/zlt2000/microservices-platform/tree/master/zlt-uaa

各個系統(tǒng)本身(sso客戶端)也需要實現(xiàn)以下邏輯:

  • 攔截請求判斷登錄狀態(tài)
  • UAA授權(quán)中心 通過 Oauth2授權(quán)碼模式 交互完成登錄/單點登錄
  • 保存用戶登錄信息

以上邏輯只需使用一個 @EnableOAuth2Sso 注解即可實現(xiàn)

SpringBoot配置如下:

下圖是訪問 sso客戶端@EnableOAuth2Sso 注解與 UAA授權(quán)中心 通過 Oauth2授權(quán)碼模式 交互完成單點登錄的步驟

請結(jié)合上面單點時序圖中單點登錄系統(tǒng)2的1~5步

PS:如果系統(tǒng)用的不是 Spring Security 怎么辦?理解原理自行實現(xiàn)

四、demo下載地址

https://gitee.com/zlt2000/microservices-platform/tree/master/zlt-demo/sso-demo

到此這篇關于一個注解搞定Spring Security基于Oauth2的SSO單點登錄功能的文章就介紹到這了,更多相關Spring Security 單點登錄內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • SpringBoot內(nèi)置數(shù)據(jù)源的持久化與解決方案

    SpringBoot內(nèi)置數(shù)據(jù)源的持久化與解決方案

    數(shù)據(jù)源的配置 我們先基于SpringBoot默認的HikariDataSource數(shù)據(jù)源,導入JDBC場景,看看SpringBoot幫我們自動配置了什么,下面我們來了解SpringBoot內(nèi)置數(shù)據(jù)源持久化
    2022-07-07
  • Java如何自定義異常打印非堆棧信息詳解

    Java如何自定義異常打印非堆棧信息詳解

    這篇文章主要給大家介紹了關于Java如何自定義異常打印非堆棧信息的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2018-04-04
  • jstorm源碼解析之bolt異常處理方法

    jstorm源碼解析之bolt異常處理方法

    下面小編就為大家?guī)硪黄猨storm源碼解析之bolt異常處理方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • 淺析JVM的垃圾回收器

    淺析JVM的垃圾回收器

    這篇文章主要介紹了JVM垃圾回收器的相關資料,幫助大家更好的理解和學習Java虛擬機的相關知識,感興趣的朋友可以了解下
    2020-11-11
  • Java實現(xiàn)班級管理系統(tǒng)

    Java實現(xiàn)班級管理系統(tǒng)

    這篇文章主要為大家詳細介紹了Java實現(xiàn)班級管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 深入剖析java中的集合框架

    深入剖析java中的集合框架

    下面小編就為大家?guī)硪黄钊肫饰鰆ava中的集合框架。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • Java中LinkedHashSet的底層機制詳解

    Java中LinkedHashSet的底層機制詳解

    這篇文章主要介紹了Java中LinkedHashSet的底層機制解讀,   LinkedHashSet是具有可預知迭代順序的Set接口的哈希表和鏈接列表實現(xiàn),此實現(xiàn)與HashSet的不同之處在于,后者維護著一個運行于所有條目的雙重鏈接列表,需要的朋友可以參考下
    2023-09-09
  • Springboot整合Swagger3全注解配置(springdoc-openapi-ui)

    Springboot整合Swagger3全注解配置(springdoc-openapi-ui)

    本文主要介紹了Springboot整合Swagger3全注解配置(springdoc-openapi-ui),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Java集合功能與用法實例詳解

    Java集合功能與用法實例詳解

    這篇文章主要介紹了Java集合功能與用法,結(jié)合實例形式詳細分析了java集合的基本概念、功能、原理、操作技巧與使用注意事項,需要的朋友可以參考下
    2020-04-04
  • 詳解Java如何利用反射提高代碼的靈活性

    詳解Java如何利用反射提高代碼的靈活性

    反射是Java語言的一種特性,它允許程序在運行時動態(tài)地獲取類的信息并操作類的屬性、方法和構(gòu)造函數(shù),使得我們的代碼更加靈活和可擴展,下面就來看看Java中反射機制的具體操作吧
    2023-05-05

最新評論