日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

CAS单点登录详细流程

發布時間:2025/3/12 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 CAS单点登录详细流程 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、CAS簡介和整體流程

CAS 是 Yale 大學發起的一個開源項目,旨在為 Web 應用系統提供一種可靠的單點登錄方法,CAS 在 2004 年 12 月正式成為 JA-SIG 的一個項目。CAS 具有以下特點:
【1】開源的企業級單點登錄解決方案。
【2】CAS Server 為需要獨立部署的 Web 應用。
【3】CAS Client 支持非常多的客戶端(這里指單點登錄系統中的各個 Web 應用),包括 Java, .Net, PHP, Perl, Apache, uPortal, Ruby 等。
從結構上看,CAS 包含兩個部分: CAS Server 和 CAS Client。CAS Server 需要獨立部署,主要負責對用戶的認證工作;CAS Client 負責處理對客戶端受保護資源的訪問請求,需要登錄時,重定向到 CAS Server。下圖是 CAS 最基本的協議過程:

SSO單點登錄訪問流程主要有以下步驟:

  • 訪問服務:SSO客戶端發送請求訪問應用系統提供的服務資源。

  • 定向認證:SSO客戶端會重定向用戶請求到SSO服務器。

  • 用戶認證:用戶身份認證。

  • 發放票據:SSO服務器會產生一個隨機的Service Ticket。

  • 驗證票據:SSO服務器驗證票據Service Ticket的合法性,驗證通過后,允許客戶端訪問服務。

  • 傳輸用戶信息:SSO服務器驗證票據通過后,傳輸用戶認證結果信息給客戶端。

  • 二、詳細登錄流程

    上圖是3個登錄場景,分別為:第一次訪問www.qiandu.com、第二次訪問、以及登錄狀態下第一次訪問mail.qiandu.com。

    下面就詳細說明上圖中每個數字標號做了什么,以及相關的請求內容,響應內容。

    1、第一次訪問www.qiandu.com

    標號1:用戶訪問http://www.qiandu.com,經過他的第一個過濾器(cas提供,在web.xml中配置)AuthenticationFilter。

    過濾器全稱:org.jasig.cas.client.authentication.AuthenticationFilter

    主要作用:判斷是否登錄,如果沒有登錄則重定向到認證中心。

    標號2:www.qiandu.com發現用戶沒有登錄,則返回瀏覽器重定向地址。

    首先可以看到我們請求www.qiandu.com,之后瀏覽器返回狀態碼302,然后讓瀏覽器重定向到cas.qiandu.com并且通過get的方式添加參數service,該參數目的是登錄成功之后會要重定向回來,因此需要該參數。并且你會發現,其實server的值就是編碼之后的我們請求www.qiandu.com的地址。

    標號3:瀏覽器接收到重定向之后發起重定向,請求cas.qiandu.com。

    標號4:認證中心cas.qiandu.com接收到登錄請求,返回登陸頁面。

    上圖就是標號3的請求,以及標號4的響應。請求的URL是標號2返回的URL。之后認證中心就展示登錄的頁面,等待用戶輸入用戶名密碼。

    標號5:用戶在cas.qiandu.com的login頁面輸入用戶名密碼,提交。

    標號6:服務器接收到用戶名密碼,則驗證是否有效,驗證邏輯可以使用cas-server提供現成的,也可以自己實現。

    上圖就是標號5的請求,以及標號6的響應了。當cas.qiandu.com即csa-server認證通過之后,會返回給瀏覽器302,重定向的地址就是Referer中的service參數對應的值。后邊并通過get的方式挾帶了一個ticket令牌,這個ticket就是ST(數字3處)。同時會在Cookie中設置一個CASTGC,該cookie是網站cas.qiandu.com的cookie,只有訪問這個網站才會攜帶這個cookie過去。

    Cookie中的CASTGC:向cookie中添加該值的目的是當下次訪問cas.qiandu.com時,瀏覽器將Cookie中的TGC攜帶到服務器,服務器根據這個TGC,查找與之對應的TGT。從而判斷用戶是否登錄過了,是否需要展示登錄頁面。TGT與TGC的關系就像SESSION與Cookie中SESSIONID的關系。

    TGT:Ticket Granted Ticket(俗稱大令牌,或者說票根,他可以簽發ST)

    TGC:Ticket Granted Cookie(cookie中的value),存在Cookie中,根據他可以找到TGT。

    ST:Service Ticket (小令牌),是TGT生成的,默認是用一次就生效了。也就是上面數字3處的ticket值。

    標號7:瀏覽器從cas.qiandu.com哪里拿到ticket之后,就根據指示重定向到www.qiandu.com,請求的url就是上面返回的url。

    標號8:www.qiandu.com在過濾器中會取到ticket的值,然后通過http方式調用cas.qiandu.com驗證該ticket是否是有效的。

    標號9:cas.qiandu.com接收到ticket之后,驗證,驗證通過返回結果告訴www.qiandu.com該ticket有效。

    標號10:www.qiandu.com接收到cas-server的返回,知道了用戶合法,展示相關資源到用戶瀏覽器上。

    至此,第一次訪問的整個流程結束,其中標號8與標號9的環節是通過代碼調用的,并不是瀏覽器發起,所以沒有截取到報文。

    2、第二次訪問www.qiandu.com

    上面以及訪問過一次了,當第二次訪問的時候發生了什么呢?

    標號11:用戶發起請求,訪問www.qiandu.com。會經過cas-client,也就是過濾器,因為第一次訪問成功之后www.qiandu.com中會在session中記錄用戶信息,因此這里直接就通過了,不用驗證了。

    標號12:用戶通過權限驗證,瀏覽器返回正常資源。

    3、訪問mail.qiandu.com

    標號13:用戶在www.qiandu.com正常上網,突然想訪問mail.qiandu.com,于是發起訪問mail.qiandu.com的請求。

    標號14:mail.qiandu.com接收到請求,發現第一次訪問,于是給他一個重定向的地址,讓他去找認證中心登錄。

    上圖可以看到,用戶請求mail.qiandu.com,然后返回給他一個網址,狀態302重定向,service參數就是回來的地址。

    標號15:瀏覽器根據14返回的地址,發起重定向,因為之前訪問過一次了,因此這次會攜帶上次返回的Cookie:TGC到認證中心。

    標號16:認證中心收到請求,發現TGC對應了一個TGT,于是用TGT簽發一個ST,并且返回給瀏覽器,讓他重定向到mail.qiandu.com

    可以發現請求的時候是攜帶Cookie:CASTGC的,響應的就是一個地址加上TGT簽發的ST也就是ticket。

    標號17:瀏覽器根據16返回的網址發起重定向。

    標號18:mail.qiandu.com獲取ticket去認證中心驗證是否有效。

    標號19:認證成功,返回在mail.qiandu.com的session中設置登錄狀態,下次就直接登錄。

    標號20:認證成功之后就反正用想要訪問的資源了。

    總結

    以上是生活随笔為你收集整理的CAS单点登录详细流程的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。