站長資訊網
        最全最豐富的資訊網站

        php單點登錄實現原理實例詳解

        php單點登錄實現原理實例詳解

        單點登錄SSO(Single Sign On)說得簡單點就是在一個多系統共存的環境下,用戶在一處登錄后,就不用在其他系統中登錄,也就是用戶的一次登錄能得到其他所有系統的信任。單點登錄在大型網站里使用得非常頻繁,例如像阿里巴巴這樣的網站,在網站的背后是成百上千的子系統,用戶一次操作或交易可能涉及到幾十個子系統的協作,如果每個子系統都需要用戶認證,不僅用戶會瘋掉,各子系統也會為這種重復認證授權的邏輯搞瘋掉。實現單點登錄說到底就是要解決如何產生和存儲那個信任,再就是其他系統如何驗證這個信任的有效性,因此要點也就以下幾個:

        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的驗證就可以辨別信息是否被改過。對于最后一個問題,可以通過白名單來處理,說簡單點只有在白名單上的系統才能請求生產信任關系,同理只有在白名單上的系統才能被免登錄。

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产成人精品免费视频网页大全| 欧美日韩国产成人高清视频,欧美日韩在线精品一 | 国产精品伦一区二区三级视频 | 亚洲精品成人网站在线观看| 四虎永久在线精品国产免费| 一本一道精品欧美中文字幕| 四虎国产精品永久地址99新强| 午夜三级国产精品理论三级 | 国产亚洲精品一品区99热| 亚洲人精品午夜射精日韩| 国产精品成人久久久久久久| 国产精品久久久久久福利漫画| 无码人妻精品一区二区三区久久 | 久久福利青草精品资源站| 国产精品福利一区二区| 无码国内精品久久人妻麻豆按摩 | 欧美日韩精品久久久久| 91嫩草亚洲精品| 国产精品99久久久久久人| 国产精品久线在线观看| 青青草原精品99久久精品66| 亚洲精品老司机在线观看| 精品人妻系列无码人妻免费视频| 欧洲精品视频在线观看| 国产精品成人va| 国产99精品久久| 精品人妻无码一区二区色欲产成人| 亚洲色精品vr一区二区三区| 中国国产精品| 中文成人无码精品久久久不卡| 少妇亚洲免费精品| 日韩精品无码久久一区二区三| 久久久久亚洲精品无码网址| 久久精品成人欧美大片| 国产三级精品三级在线观看专1| 91精品成人免费国产片 | 国产精品视频免费观看| 99re6在线精品免费观看| CAOPORM国产精品视频免费| 国产精品免费大片| 国产美女久久精品香蕉69|