java - 關(guān)于Spring MVC登錄系統(tǒng)的設計
問題描述
我現(xiàn)在的想法是定義一個User對象,其中包括uid, username, password, isLogined等。然后設置一個攔截器,在用戶第一次請求(session開始)的時候,從數(shù)據(jù)庫中根據(jù)user.isLogined判斷用戶是否登錄,如果登錄了就在session級別上設置isLogined等于true,否則就重定向到登錄頁面。
但是這樣的話在用戶第一次請求的時候,我應該如何判斷用戶的身份?如果通過在cookie中設置uid的話,這個uid可以被其他人偽造,有潛在的安全風險。
請問對于這個問題,有什么好的解決方案?
補充我主要的問題就是如何判斷用戶登錄身份的合法性,現(xiàn)在我的想法是將user id加密之后保存到cookie當中,這把密鑰只有我一個人知道,這樣別人即使知道user id也沒有辦法,請問這樣是否合理。
問題解答
回答1:這個風險好大:uid修改為別人的,碰巧那人也登錄了,那么就以別人的身份登錄了
沿著你的方案走:1,cookie的uid設置為加密的,或者是無意義的隨機串2,用這個串和db里比對,或者和cache里的比對,同時校驗ip或者user agent加強安全性3,要考慮會話過期策略
回答2:首先你的數(shù)據(jù)庫中需要先存儲用戶信息,設置isLogined 默認為FALSE,每次登陸成功后更新為TRUE,退出后更新為FALSE;判斷登陸成功的標志用userName userPass 匹配,還有isLogined 判斷;最后設置判斷級別,先isLogined 后 用戶密碼;
回答3:建議登錄狀態(tài)不要存儲在數(shù)據(jù)庫中,至少也別存在關(guān)系型數(shù)據(jù)庫中;可以在用戶登錄校驗完成后,返回token,之后用戶的所有請求在headers的authorization字段都帶上這個token;可以去了解一下jwt及相關(guān)實現(xiàn)
回答4:就按你現(xiàn)在的方式,如果我一個匿名用戶,沒登錄,去請求你的某個接口,然后被攔截從數(shù)據(jù)庫中根據(jù)user.isLogined判斷用戶是否登錄,那么問題來了。你user.isLogined中的這個user是誰呢?
建議直接登錄后把用戶登錄成功信息放session里,請求的時候攔截器去驗證session就好了,不要去訪問數(shù)據(jù)庫,每次請求都有這一個訪問數(shù)據(jù)庫操作很有消耗的。
相關(guān)文章:
1. mysql - 這條聯(lián)合sql語句哪里錯了2. mysql優(yōu)化 - 關(guān)于mysql分區(qū)3. 請教各位大佬,瀏覽器點 提交實例為什么沒有反應4. java - Atom中文問題5. java - MySQL中,使用聚合函數(shù)+for update會鎖表嗎?6. css3 - 這個形狀使用CSS怎么寫出來?7. javascript - 為什么這個點擊事件需要點擊兩次才有效果8. node.js - 在vuejs-templates/webpack中dev-server.js里為什么要exports readyPromise?9. javascript - ionic2 input autofocus 電腦成功,iOS手機鍵盤不彈出10. java - C語言算法題-韓信點兵 求解?
