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. javascript - node.js promise沒用2. golang - 用IDE看docker源碼時的小問題3. c++ - 如何正確的使用QWebEngineView?4. yii2中restful配置好后在nginx下報404錯誤5. javascript - js 寫一個正則 提取文本中的數(shù)據(jù)6. 算法 - python 給定一個正整數(shù)a和一個包含任意個正整數(shù)的 列表 b,求所有<=a 的加法組合7. android 如何實現(xiàn)如圖中的鍵盤上的公式及edittext的內(nèi)容展示呢8. java - 我在用Struts2上傳文件時,報以下錯誤怎么回事?9. php自學(xué)從哪里開始?10. 有會apicloud 混合開發(fā)的朋友嗎?
