flask - python web中如何共享登錄狀態(tài)?
問題描述
在一個域名下面會有好多個子域名,每個子域名對應(yīng)一個子系統(tǒng),這些子系統(tǒng)有的是用DJANGO,有的是用Flask等不同的框架開發(fā),那么,我們?nèi)绾卧谶@不同系統(tǒng)間共享登錄狀態(tài)?也就是說,只要在某一個系統(tǒng)登錄了,在使用其他系統(tǒng)的時候也共享著登錄的狀態(tài),不需要再次登錄,除非登錄失效。這樣的話要怎么做呢?
問題解答
回答1:看看什么叫單點登錄
回答2:可以參考:https://github.com/castlabs/d...
你也可以自己實現(xiàn):1、搞一個用戶中心(用于賬戶管理、登錄等)2、訪問一個子系統(tǒng),先判斷是否有token。如果沒有,或者已過期,則自動跳轉(zhuǎn)到用戶中心。3、用戶中心登錄成功以后,生成一個token,并跳轉(zhuǎn)回之前要訪問的子系統(tǒng)(帶上token)4、再訪問別的系統(tǒng)時,都需要帶上這個token。
還有個辦法,不需要顯式的帶token:用戶中心登錄成功以后,cookie還保存登錄信息。訪問各個子系統(tǒng)(頁面加載)的時候,通過jsonp去用戶中心校驗是否已登錄:假如用戶中心域名www.a.com,那么瀏覽器會緩存該域名及其對應(yīng)的cookie;而jsonp跨域去請求www.a.com的時候,會自動帶上這個cookie的。
相關(guān)文章:
1. macos - mac下docker如何設(shè)置代理2. java - 請問在main方法中寫成對象名.屬性()并賦值,與直接參參數(shù)賦值輸錯誤是什么原因?3. MySQL數(shù)據(jù)庫中文亂碼的原因4. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””5. docker不顯示端口映射呢?6. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?7. android studio總是在processes running好久8. angular.js - 關(guān)于$apply()9. docker-compose 為何找不到配置文件?10. dockerfile - 我用docker build的時候出現(xiàn)下邊問題 麻煩幫我看一下
