您好,登錄后才能下訂單哦!
這篇文章主要介紹了實現(xiàn)php單點登錄的方法,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。
單點登錄(Single Sign On),簡稱為SSO,是目前比較流行的企業(yè)業(yè)務(wù)整合的解決方案之一。SSO的定義是在多個應(yīng)用系統(tǒng)中,用戶只需要登錄一次就可以訪問所有相互信任的應(yīng)用系統(tǒng)。
推薦閱讀:php服務(wù)器
實現(xiàn)單點登錄的方法
server端
“共享Cookie”即共享session的方式,本質(zhì)上cookie只是存儲session-id的介質(zhì),session-id也可以放在每次請求的url里面.session機制是一個server一個session
SSO-Token方式是因為共享session的方式不安全,所以我們不再以session-id作為身份的標(biāo)識,我們另外生成一種標(biāo)識,把它取名為SSO-Token,這種標(biāo)識在整個server群唯一的,所以所有的server群都能驗證整個token,同時拿到token 就代表拿到用戶的信息
瀏覽器端
單點登錄還有非常關(guān)鍵的一步,這一步跟server端驗證token的方式無關(guān),用最早的“共享session”的方式還是現(xiàn)在的“token”方式,身份標(biāo)識到了瀏覽器端都要面臨這樣的一個問題:用戶登錄成功拿到token(或者是session-id)后怎么讓瀏覽器存儲和分享到其它域名下?
同域名很簡單,把token存在cookie里,把cookie的路徑設(shè)置成頂級域名下,這樣所有子域都能讀取cookie中的token。這就是共享cookie的方式(這才叫共享Cookie嘛,上面那個應(yīng)該叫共享session)。
技術(shù)實現(xiàn)的機制
當(dāng)用戶第一次訪問應(yīng)用系統(tǒng)的時候,因為還沒有登錄,會被引導(dǎo)到認(rèn)證系統(tǒng)中進行登錄;根據(jù)用戶提供的登錄信息,認(rèn)證系統(tǒng)進行身份校驗,如果通過校驗,應(yīng)該返回給用戶一個認(rèn)證的憑據(jù)-ticket;
用戶再訪問別的應(yīng)用的時候,就會將這個ticket帶上,作為自己認(rèn)證的憑據(jù),應(yīng)用系統(tǒng)接受到請求之后會把ticket送到認(rèn)證系統(tǒng)進行校驗,檢查ticket的合法性。如果通過校驗,用戶就可以在不用再次登錄的情況下訪問應(yīng)用系統(tǒng)2和應(yīng)用系統(tǒng)3了。
要實現(xiàn)SSO,需要以下主要的功能:
所有應(yīng)用系統(tǒng)共享一個身份認(rèn)證系統(tǒng)。
統(tǒng)一的認(rèn)證系統(tǒng)是SSO的前提之一。認(rèn)證系統(tǒng)的主要功能是將用戶的登錄信息和用戶信息庫相比較,對用戶進行登錄認(rèn)證;認(rèn)證成功后,認(rèn)證系統(tǒng)應(yīng)該生成統(tǒng)一的認(rèn)證標(biāo)志(ticket),返還給用戶。另外,認(rèn)證系統(tǒng)還應(yīng)該對ticket進行效驗,判斷其有效性。
所有應(yīng)用系統(tǒng)能夠識別和提取ticket信息。
要實現(xiàn)SSO的功能,讓用戶只登錄一次,就必須讓應(yīng)用系統(tǒng)能夠識別已經(jīng)登錄過的用戶。應(yīng)用系統(tǒng)應(yīng)該能對ticket進行識別和提取,通過與認(rèn)證系統(tǒng)的通訊,能自動判斷當(dāng)前用戶是否登錄過,從而完成單點登錄的功能。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享實現(xiàn)php單點登錄的方法內(nèi)容對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。