亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

php如何實現單點登錄

發布時間:2020-09-22 10:14:29 來源:億速云 閱讀:319 作者:小新 欄目:編程語言

小編給大家分享一下php如何實現單點登錄,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

php實現單點登錄的原理是:首先將信任存儲在客戶端的cookie中;然后進一步驗證cookie即可。為了高效存儲大量臨時性的信任數據,可以采用類似與memcached的分布式緩存的方案。

php如何實現單點登錄

單點登錄SSO(Single Sign On)說得簡單點就是在一個多系統共存的環境下,用戶在一處登錄后,就不用在其他系統中登錄,也就是用戶的一次登錄能得到其他所有系統的信任。

(相關推薦:php培訓)

單點登錄在大型網站里使用得非常頻繁,例如像阿里巴巴這樣的網站,在網站的背后是成百上千的子系統,用戶一次操作或交易可能涉及到幾十個子系統的協作;

如果每個子系統都需要用戶認證,不僅用戶會瘋掉,各子系統也會為這種重復認證授權的邏輯搞瘋掉。

實現單點登錄說到底就是要解決如何產生和存儲那個信任,再就是其他系統如何驗證這個信任的有效性;

因此要點也就以下幾個:

1、存儲信任

2、驗證信任

只要解決了以上的問題,達到了開頭講得效果就可以說是SSO。

最簡單實現SSO的方法就是用Cookie,實現流程如下所示:

php如何實現單點登錄

不難發現以上的方案是把信任存儲在客戶端的Cookie里,這種方法雖然實現方便但立馬會讓人質疑兩個問題:

1、Cookie不安全

2、不能跨域免登

對于第一個問題一般都是通過加密Cookie來處理,第二個問題是硬傷,其實這種方案的思路的就是要把這個信任關系存儲在客戶端,要實現這個也不一定只能用Cookie,用flash也能解決,flash的Shared Object API就提供了存儲能力。

一般說來,大型系統會采取在服務端存儲信任關系的做法,實現流程如下所示:

php如何實現單點登錄

以上方案就是要把信任關系存儲在單獨的SSO系統(暫且這么稱呼它)里,說起來只是簡單地從客戶端移到了服務端,但其中幾個問題需要重點解決:

1、如何高效存儲大量臨時性的信任數據

2、如何防止信息傳遞過程被篡改

3、如何讓SSO系統信任登錄系統和免登系統

對于第一個問題,一般可以采用類似與memcached的分布式緩存的方案,既能提供可擴展數據量的機制,也能提供高效訪問。

對于第二個問題,一般采取數字簽名的方法,要么通過數字證書簽名,要么通過像md5的方式,這就需要SSO系統返回免登URL的時候對需驗證的參數進行md5加密,并帶上token一起返回;

最后需免登的系統進行驗證信任關系的時候,需把這個token傳給SSO系統,SSO系統通過對token的驗證就可以辨別信息是否被改過。

對于最后一個問題,可以通過白名單來處理,說簡單點只有在白名單上的系統才能請求生產信任關系,同理只有在白名單上的系統才能被免登錄。

看完了這篇文章,相信你對php如何實現單點登錄有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

岐山县| 三穗县| 乐平市| 曲麻莱县| 八宿县| 自治县| 客服| 海安县| 兴业县| 奇台县| 宁陵县| 互助| 天祝| 吉林省| 东辽县| 城市| 吉木萨尔县| 嘉善县| 嘉兴市| 南安市| 华容县| 丰城市| 松原市| 开原市| 江口县| 竹溪县| 凤山市| 大埔县| 太和县| 池州市| 赤城县| 治多县| 兴仁县| 建宁县| 社会| 山东省| 灵石县| 长海县| 香格里拉县| 青州市| 临汾市|