casphp單點登錄
❶ php cas單點登錄如何獲取用戶信息而不跳轉到登錄頁
asjx 獲取cookies 即可
❷ CAS單點登錄原理分析(一)
一,業務分析
在分布式系統架構中,假設把上述的三個子系統部署在三個不同的伺服器上。前提是用戶登錄之後才能訪問這些子系統。那麼使用傳統方式,可能會存在這樣的問題:
1.當訪問用戶中心,需要用戶登錄帳號
2.當訪問購物車,還需要用戶登錄帳號
3.當訪問商品結算,又一次需要用戶登錄帳號
訪問每一個子系統都需要用戶登錄帳號,這樣的體驗對於用戶來說是極差。而使用單點登錄就可以很好地解決上述的問題。
二,單點登錄
單點登錄(Single Sign On),簡稱為 SSO,是目前比較流行的企業業務整合的解決方案之一。SSO 的定義是在多個應用系統中,用戶只需要登錄一次就可以訪問所有相互信任的應用系統。
我們目前的系統存在諸多子系統,而這些子系統是分別部署在不同的伺服器中,那麼使用傳統方式的 session 是無法解決的,我們需要使用相關的單點登錄技術來解決。
第一步 :用戶訪問應用系統1。過濾器判斷用戶是否登錄,沒有登錄,則重定向(302)到認證系統去進行認證操作。
第二步 :重定向到認證系統,顯示登錄界面,用戶輸入用戶名密碼。認證系統將用戶登錄的信息記錄到伺服器的session中。
第三步 :認證系統給瀏覽器發送一個特殊的憑證ticket,瀏覽器將憑證交給應用系統1,應用系統1則拿著瀏覽器交給他的憑證ticket去認證系統驗證憑證ticket是否有效。憑證ticket若是有效,將用戶信息保存到應用系統1的session中一份,並告知應用系統1,用戶通過認證。
第四步 :用戶通過認證,瀏覽器與網站之間進行正常的訪問。
第五步 :當用戶再次訪問應用系統1,由於應用系統1的session中有用戶信息,所以就不用經過認證系統認證,就可以直接訪問應用系統1了。
第六步 :當用戶再去訪問其他應用系統時,瀏覽器會帶著憑證ticket過去,其他應用系統到認證系統驗證憑證,憑證ticket若是有效,將用戶信息保存到其他應用系統的session中一份,並告知其他應用系統,用戶通過認證。
第七步 :用戶通過認證,瀏覽器與網站之間進行正常的訪問。
第八步 :當用戶再次訪問其他應用系統,由於其他應用系統的session中有用戶信息,所以就不用經過認證系統認證,就可以直接訪問其他應用系統了。
三、Yelu大學研發的CAS(Central Authentication Server)
1.什麼是CAS?
CAS 是 Yale 大學發起的一個開源項目,旨在為 Web 應用系統提供一種可靠的單點登錄方法,CAS 在 2004 年 12 月正式成為 JA-SIG 的一個項目。CAS 具有以下特點:
【1】開源的企業級單點登錄解決方案。
【2】CAS Server 為需要獨立部署的 Web 應用。這個CAS框架已經提供
【3】CAS Client 支持非常多的客戶端(這里指單點登錄系統中的各個 Web 應用),包括java, .Net, PHP, Perl, Apache, uPortal, Ruby 等。
從結構上看,CAS 包含兩個部分: CAS Server 和 CAS Client。CAS Server 需要獨立部署,主要負責對用戶的認證工作;CAS Client 負責處理對客戶端受保護資源的訪問請求,需要登錄時,重定向到 CAS Server。下圖是 CAS 最基本的協議過程:
2.CAS的詳細登錄流程
該圖主要描述
1.第一次訪問http://shopping.xiaogui.com
2.在登錄狀態下第二次訪問http://shopping.xiaogui.com
3.在登錄狀態下第一次訪問http://pay.xiaogui.com
下面對圖中序號代表的操作進行說明
當用戶第一次訪問http://shopping.xiaogui.com
序號1: 用戶請求http://shopping.xiaogui.com,會經過AuthenticationFilter認證過濾器(在cas client 的web.xml中配置)
主要作用:判斷是否登錄,如果沒有登錄則重定向到認證中心。
大概知道這個就行,CAS的具體實現會在以後的博客中寫道
序號2: AuthenticationFilter發現用戶沒有登錄,則返回瀏覽器重定向地址。
重定向的地址就是認證伺服器CAS Server的地址,後面的參數是我們請求的客戶端地址,這個參數目的就是為了認證成功以後,根據這個參數的地址重定向回請求的客戶端
序號3: 瀏覽器根據響應回來的重定向地址,向cas.xiaogui.com認證系統發出請求
序號4: 認證系統cas.xiaogui.com接收請求,響應登陸頁面
序號5: :用戶登陸頁面輸入用戶名密碼,提交請求
序號6: :CAS Server 認證伺服器接收用戶名和密碼,就行驗證,驗證邏輯CAS Server 已經實現,並響應給瀏覽器信息
這里的用戶名,密碼不需要關心,後續會講到
圖中1,2部分表示序號5 輸入的用戶名,密碼,以及發出的請求。當認證伺服器驗證通過之後,根據請求參數service的值,進行重定向,其實就是回到了請求的客戶端,同時會攜帶一個ticket令牌參數。同時會在Cookie中設置一個TGC,該cookie是網站認證系統cas.xiaogui.com的cookie,只有訪問這個網站才會攜帶這個cookie過去。
*****注意:這個攜帶TGC的Cookie是實現CAS單點登錄的關鍵所在!
Cookie中的TGC:向cookie中添加該值的目的是當下次訪問cas.xiaogui.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: 客戶端拿到請求中的ticket信息,也就是圖中1的位置
然後經過一個ticket過濾器,去認證系統CAS Server判斷ticket是否有效
這個過濾器的主要工作就是校驗客戶端傳過來的ticket是否有效
CAS Client 客戶端 shopping.xiaogui.com 中web.xml的配置
序號8: 向CAS Server認證系統發出驗證ticket的請求,也就是圖中2的位置,然後執行ticket驗證
序號9: 通過校驗之後,把用戶信息保存到客戶端的session中,並把客戶端的SessionID設置在Cookie中,同時告知客戶端ticket有效。當用戶再次訪問該客戶端,就可以根據Cookie 中的SessionID找到客戶端的Session,獲取用戶信息,就不用再次進行驗證了。也就是圖中響應給瀏覽器的部分。
序號10: shopping.xiaogui.com客戶端接收到cas-server的返回,知道了用戶已經登錄,ticket有效,告知瀏覽器可以進行訪問。
至此,用戶第一次訪問流程結束。
當用戶第二次訪問http://shopping.xiaogui.com
序號11: 當用戶第二次訪問,仍然會經過AuthenticationFilter過濾器,但與第一次訪問不同的是此時客戶端session中已經存在用戶的信息,瀏覽器中的Cookie會根據SessionID找到Session,獲取用戶信息,所以不需要進行驗證,可以直接訪問。
序號12: 客戶端告知瀏覽器可以進行訪問。
當用戶第一次訪問http://pay.xiaogui.com
序號13: 用戶向pay.xiaogui.com CAS Client客戶端發出請求
序號14: :pay.xiaogui.com接收到請求,發現第一次訪問,於是給他一個重定向的地址,讓他去找認證中心登錄。
序號15: 瀏覽器根據上面響應的地址,發起重定向,因為之前訪問過一次了,因此這次會攜帶上次返回的Cookie:TGC到認證中心。
序號16: 認證中心收到請求,發現TGC對應了一個TGT,於是用TGT簽發一個ticket,並且返回給瀏覽器,讓他重定向到pay.xiaogui.comCAS Client客戶端。
序號17: 根據上面響應回來的地址,進行重定向到pay.xiaogui.comCAS Client客戶端
序號18: pay.xiaogui.comCAS Client客戶端帶著ticket去認證中心驗證是否有效。
序號19: 認證成功,把用戶信息保存到客戶端的session中,並把客戶端的SessionID設置在Cookie中。當用戶下次訪問pay.xiaogui.comCAS Client客戶端,直接登錄,無需驗證。
序號20: 告知瀏覽器可以進行訪問
CAS單點登錄的原理分析大致就是上述的這些,至於CAS單點登錄的具體實現,將在下篇博客中寫道。
❸ CAS 單點登錄原理解析
CAS是耶魯大學發起的一個開源單點登錄項目,也是用的最為廣泛的開源項目。對於學習SSO有非常好的參考價值
單點登錄(Single Sign On),簡稱為 SSO。多用於多系統共存的環境下,用戶在一處登錄後,就不用在其他系統中登錄,最簡單的單點登入實現可以完全基於 cookie ,通過往瀏覽器寫帶有登入信息的token來達到多點登入的目的,有興趣的可以自己動手實現一個
先盜個圖 :
從結構上看,分成了三部分:CAS Client,CAS Server,瀏覽器
CAS Client 與受保護的客戶端應用部署在一起,以 Filter 方式保護 Web 應用的受保護資源,過濾從客戶端過來的每一個Web請求
下面我將分為兩部分(用戶第一次登錄驗證和之後的登錄驗證)詳細解析其登入原理
以上是第一次驗證時基本流程
跨域的關鍵在於瀏覽器端的Cookie: TGC ,因為這個Cookie是設置在 SSO Server 端的,也就保證了統一票據和 Client 端域名無關。
cas 單點登錄核心就是 單個cookie , N個session
在該協議中,所有與 CAS Server 的交互均採用 SSL 協議,以確保 ST 和 TGC 的安全性。
❹ cas單點登錄流程
第一步:訪問cas過濾鏈接ssoLogin,拼湊定向到 CAS_SERVER 獲取ticket的URL
第二步:CAS_SERVER校驗用戶信息,生成Ticket
第三步:重新定向到訪問客戶端的ssoLogin並附加Ticket參數和值
第四步:根據傳來的Ticket拼湊定向到CAS_SERVER的連接去校驗Ticket的合法性
第五步:CAS_SERVER校驗成功後,會返回XML報文並重新定向到訪問客戶端的ssoLogin
解析該XML報文,構造用戶信息對象存儲在session中
然後根據ssoLogin設置的loginSuccessUrl跳轉到登錄成功後的訪問頁面
❺ php cas單點登錄,無登陸信息的話,系統自動轉到登陸頁面,請問:如何不讓系統自動轉到登陸頁面
你換一個跳轉地址就好了啊
❻ 如何配置CAS php 單點登錄求詳簡。。。
你可以試試這個方法:你得用redirect來保證cookie被存到瀏覽器,不過我覺得你也可以用javascript發送http請求來保證cookie
被記錄在第二個domain下面。
What
we
have
implemented
on
a
few
sites
that
use
a
single
sign
on
is
a
round
trip
login
process.
The
user
authenticates
on
the
first
domain,
we
encrypt
the
login
details,
and
redirect
them
to
a
known
page
on
the
second
domain,
log
them
in
there,
and
then
redirect
back
to
the
original
server.
This
client
side
redirection
is
important
-
cookies
are
only
written
when
there
is
a
response
back
to
the
client,
and
the
browser
has
to
visit
the
second
domain
to
actually
see
the
cookies.
❼ phpcas登錄遇到的問題
使用apereo/phpcas包完成單點登錄,某一次項目中,本地測試沒有問題發布線上之後cas登錄頁出現Error Internal script failure。
看到Error Internal script failure這個錯誤,完全不知道問題出在哪裡,各種搜索沒有找到答案,無奈進入源碼。看到一個log方法,好像是用來記日誌的,判斷的filename存在就記錄日誌,繼續找到看到了setDebug,在setDebug中去設置了日誌文件目錄之後就可以記錄日誌了通過日誌看具體問題。
終於在日誌里看出了問題在寫入session時文件沒有寫入許可權導致cas登錄失敗
❽ php 怎麼實現單點登錄
單點登錄(Single Sign On),簡稱為 SSO,是目前比較流行的企業業務整合的解決方案之一。SSO的定義是在多個應用系統中,用戶只需要登錄一次就可以訪問所有相互信任的應用系統。(網路)
我本人認為單點登錄主要解決一下問題:
1. 一個用戶賬號,多站點通用;
2. 一個應用登錄,其他應用同時登錄;
3. 一個賬號退出,其他應用賬號同時退出;(非必須,此項不在單點登錄的討論范圍之內,不過WEB單點登錄,用到的還是挺多的);
4. 歡迎補充
PHP實現單點登錄方法有多種:
1. 通過關系服務 如webservice 之類的;
2. 資料庫共享session實現;
4. P3P跨站點 如ucenter phpcms 等;
5. 通過文件操作 SESSIONID
6. 歡迎補充
❾ 什麼是cas單點登錄
CAS是一個單點登錄框架,開始是由耶魯大學的一個組織開發,後來歸到apereo去管。 同時CAS也是開源,遵循著apache 2.0協議,代碼目前是在github上管理。單點登錄:Single Sign On,簡稱SSO,SSO使得在多個應用系統中,用戶只需要登錄一次就可以訪問所有相互信任的應用系統。CAS 是 Yale 大學發起的一個開源項目,旨在為 Web 應用系統提供一種可靠的單點登錄方法,CAS 在 2004 年 12 月正式成為 JA-SIG 的一個項目。cas單點登錄目前國內玉符科技技術實力可以,可以考察,望採納!
❿ CAS搭建單點登錄Web端
①前端vue項目判斷如果有token,則說明用戶已登錄,可以訪問客戶端A的服務。否則未登陸,未登陸有兩種狀態:在單點登錄服務端已經登錄和未在單點登錄服務端登陸
判斷如果有ticket,則說明已在單點登錄服務端登錄。調用/cas/client/validateLogin介面驗證該ticket是否有效。轉②
判斷如果無ticket,則說明未在單點登錄服務端登錄。則定向到單點登錄服務端。轉③
②/cas/client/validateLogin介面方法,發起http請求到單點登錄服務端進行ticket驗證,如果驗證通過,則登錄成功。單點登錄客戶端A生成token返回給前端,之後前端通過攜帶token訪問客戶端A的服務。
③單點登錄服務端返回登錄表單,用戶輸入用戶名密碼確定登錄後,單點登錄服務端調用用戶信息驗證端/auth/user/login介面,傳遞用戶名密碼參數,將驗證委託給用戶信息驗證端
④登錄成功驗證通過後,攜帶ticket返回瀏覽器,重定向地址如下:
http://localhost:8000/?ticket=ST-6-NqvtyjRhezstXiyyzNNN-C-DiTw-DESKTOP-CVVQ0QK
接入用戶信息驗證端參考