1. 程式人生 > >單點登錄

單點登錄

images 應用程序 地址 判斷 自己 泄露 所有應用 ticket 密碼

一、什麽是單點登錄SSO(Single Sign-On)

  SSO是一種統一認證和授權機制,指訪問同一服務器不同應用中的受保護資源的同一用戶,只需要登錄一次,即通過一個應用中的安全驗證後,再訪問其他應用中的受保護資源時,不再需要重新登錄驗證。

二、單點登錄解決了什麽問題

  解決了用戶只需要登錄一次就可以訪問所有相互信任的應用系統,而不用重復登錄。

三、單點登錄的技術實現機制

  如下圖所示:

  

技術分享

    當用戶第一次訪問應用系統1的時候,因為還沒有登錄,會被引導到認證系統中進行登錄;根據用戶提供的登錄信息,認證系統進行身份效驗,如果通過效驗,應該返回給用戶一個認證的憑據--ticket;用戶再訪問別的應用的時候,就會將這個ticket帶上,作為自己認證的憑據,應用系統接受到請求之後會把ticket送到認證系統進行效驗,檢查ticket的合法性(4,6)。如果通過效驗,用戶就可以在不用再次登錄的情況下訪問應用系統2和應用系統3了。

從上圖可以看出sso的實現技術點:

  1)所有應用系統共享一個身份認證系統

    統一的認證系統是SSO的前提之一。認證系統的主要功能是將用戶的登錄信息和用戶信息庫相比較,對用戶進行登錄認證;認證成功後,認證系統應該生成統一的認證標誌(ticket),返還給用戶。另外,認證系統還應該對ticket進行效驗,判斷其有效性。

  2)所有應用系統能夠識別和提取ticket信息

    要實現SSO的功能,讓用戶只登錄一次,就必須讓應用系統能夠識別已經登錄過的用戶。應用系統應該能對ticket進行識別和提取,通過與認證系統的通訊,能自動判斷當前用戶是否登錄過,從而完成單點登錄的功能。

關於統一身份認證機制

:如下圖

技術分享

  ①用戶請求訪問業務系統。

  ②業務系統在系統中查看是否有對應請求的有效令牌,若有,則讀取對應的身份信息,允許其訪問;若沒有或令牌無效,則把用戶重定向到統一身份認證平臺,並攜帶業務系統地址,進入第③步。

  ③在統一身份認證平臺提供的頁面中,用戶輸入身份憑證信息,平臺驗證此身份憑證信息,若有效,則生成一個有效的令牌給用戶,進入第④步;若無效,則繼續進行認證,直到認證成功或退出為止。

  ④用戶攜帶第③步獲取的令牌,再次訪問業務系統。

  ⑤業務系統獲取用戶攜帶的令牌,提交到認證平臺進行有效性檢查和身份信息獲取。

  ⑥若令牌通過有效性檢查,則認證平臺會把令牌對應的用戶身份信息返回給業務系統,業務系統把身份信息和有效令牌寫入會話狀態中,允許用戶以此身份信息進行業務系統的各種操作;若令牌未通過有效性檢查,則會再次重定向到認證平臺,返回第③步。

  通過統一身份認證平臺獲取的有效令牌,可以在各個業務系統之間實現應用漫遊。

四、單點登錄的優點

  1)提高用戶的效率。

    用戶不再被多次登錄困擾,也不需要記住多個 ID 和密碼。另外,用戶忘記密碼並求助於支持人員的情況也會減少。

  2)提高開發人員的效率。

    SSO 為開發人員提供了一個通用的身份驗證框架。實際上,如果 SSO 機制是獨立的,那麽開發人員就完全不需要為身份驗證操心。他們可以假設,只要對應用程序的請求附帶一個用戶名,身份驗證就已經完成了。

  3)簡化管理。

    如果應用程序加入了單點登錄協議,管理用戶帳號的負擔就會減輕。簡化的程度取決於應用程序,因為 SSO 只處理身份驗證。所以,應用程序可能仍然需要設置用戶的屬性(比如訪問特權)。

五、單點登錄的缺點

  1)不利於重構

    因為涉及到的系統很多,要重構必須要兼容所有的系統,可能很耗時

  2) 無人看守桌面

    因為只需要登錄一次,所有的授權的應用系統都可以訪問,可能導致一些很重要的信息泄露。

單點登錄