flask - python web中如何共享登錄狀態(tài)?
問題描述
在一個域名下面會有好多個子域名,每個子域名對應一個子系統(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,那么瀏覽器會緩存該域名及其對應的cookie;而jsonp跨域去請求www.a.com的時候,會自動帶上這個cookie的。
相關(guān)文章:
1. macos - mac 重啟后 XAMPP下的apache無法啟動2. css3 - 這個右下角折角用css怎么畫出來?3. mysql - eclispe無法打開數(shù)據(jù)庫連接4. windows2003下的apache響應時間特別長?5. javascript - 在 model里定義的 引用表模型時,model為undefined。6. 關(guān)于Java引用傳遞的一個困惑?7. java - 根據(jù)月份查詢多個表里的內(nèi)容怎么實現(xiàn)好?8. javascript - 一個關(guān)于客戶端和前端通信的疑惑?9. php - 一個操作請求多個服務如何保證數(shù)據(jù)的安全?10. javascript - webpack熱加載配置不生效
