小編給大家分享一下php如何實(shí)現(xiàn)單點(diǎn)登錄,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
為歷城等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及歷城網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、歷城網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!php實(shí)現(xiàn)單點(diǎn)登錄的原理是:首先將信任存儲(chǔ)在客戶端的cookie中;然后進(jìn)一步驗(yàn)證cookie即可。為了高效存儲(chǔ)大量臨時(shí)性的信任數(shù)據(jù),可以采用類似與memcached的分布式緩存的方案。
單點(diǎn)登錄SSO(Single Sign On)說得簡(jiǎn)單點(diǎn)就是在一個(gè)多系統(tǒng)共存的環(huán)境下,用戶在一處登錄后,就不用在其他系統(tǒng)中登錄,也就是用戶的一次登錄能得到其他所有系統(tǒng)的信任。
(相關(guān)推薦:php培訓(xùn))
單點(diǎn)登錄在大型網(wǎng)站里使用得非常頻繁,例如像阿里巴巴這樣的網(wǎng)站,在網(wǎng)站的背后是成百上千的子系統(tǒng),用戶一次操作或交易可能涉及到幾十個(gè)子系統(tǒng)的協(xié)作;
如果每個(gè)子系統(tǒng)都需要用戶認(rèn)證,不僅用戶會(huì)瘋掉,各子系統(tǒng)也會(huì)為這種重復(fù)認(rèn)證授權(quán)的邏輯搞瘋掉。
實(shí)現(xiàn)單點(diǎn)登錄說到底就是要解決如何產(chǎn)生和存儲(chǔ)那個(gè)信任,再就是其他系統(tǒng)如何驗(yàn)證這個(gè)信任的有效性;
因此要點(diǎn)也就以下幾個(gè):
1、存儲(chǔ)信任
2、驗(yàn)證信任
只要解決了以上的問題,達(dá)到了開頭講得效果就可以說是SSO。
最簡(jiǎn)單實(shí)現(xiàn)SSO的方法就是用Cookie,實(shí)現(xiàn)流程如下所示:
不難發(fā)現(xiàn)以上的方案是把信任存儲(chǔ)在客戶端的Cookie里,這種方法雖然實(shí)現(xiàn)方便但立馬會(huì)讓人質(zhì)疑兩個(gè)問題:
1、Cookie不安全
2、不能跨域免登
對(duì)于第一個(gè)問題一般都是通過加密Cookie來處理,第二個(gè)問題是硬傷,其實(shí)這種方案的思路的就是要把這個(gè)信任關(guān)系存儲(chǔ)在客戶端,要實(shí)現(xiàn)這個(gè)也不一定只能用Cookie,用flash也能解決,flash的Shared Object API就提供了存儲(chǔ)能力。
一般說來,大型系統(tǒng)會(huì)采取在服務(wù)端存儲(chǔ)信任關(guān)系的做法,實(shí)現(xiàn)流程如下所示:
以上方案就是要把信任關(guān)系存儲(chǔ)在單獨(dú)的SSO系統(tǒng)(暫且這么稱呼它)里,說起來只是簡(jiǎn)單地從客戶端移到了服務(wù)端,但其中幾個(gè)問題需要重點(diǎn)解決:
1、如何高效存儲(chǔ)大量臨時(shí)性的信任數(shù)據(jù)
2、如何防止信息傳遞過程被篡改
3、如何讓SSO系統(tǒng)信任登錄系統(tǒng)和免登系統(tǒng)
對(duì)于第一個(gè)問題,一般可以采用類似與memcached的分布式緩存的方案,既能提供可擴(kuò)展數(shù)據(jù)量的機(jī)制,也能提供高效訪問。
對(duì)于第二個(gè)問題,一般采取數(shù)字簽名的方法,要么通過數(shù)字證書簽名,要么通過像md5的方式,這就需要SSO系統(tǒng)返回免登URL的時(shí)候?qū)π栩?yàn)證的參數(shù)進(jìn)行md5加密,并帶上token一起返回;
最后需免登的系統(tǒng)進(jìn)行驗(yàn)證信任關(guān)系的時(shí)候,需把這個(gè)token傳給SSO系統(tǒng),SSO系統(tǒng)通過對(duì)token的驗(yàn)證就可以辨別信息是否被改過。
對(duì)于最后一個(gè)問題,可以通過白名單來處理,說簡(jiǎn)單點(diǎn)只有在白名單上的系統(tǒng)才能請(qǐng)求生產(chǎn)信任關(guān)系,同理只有在白名單上的系統(tǒng)才能被免登錄。
看完了這篇文章,相信你對(duì)php如何實(shí)現(xiàn)單點(diǎn)登錄有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!
當(dāng)前標(biāo)題:php如何實(shí)現(xiàn)單點(diǎn)登錄-創(chuàng)新互聯(lián)
本文地址:http://aaarwkj.com/article24/pjece.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、電子商務(wù)、App設(shè)計(jì)、用戶體驗(yàn)、ChatGPT、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容