spring mvc實現(xiàn)登錄賬號單瀏覽器登錄
在很多web產(chǎn)品中都需要實現(xiàn)在同一時刻,只能允許一個賬號同時只能在一個瀏覽器當中登錄。通俗點講就是當A賬號在瀏覽器1當中登錄了,此時在瀏覽器2中登錄A賬號。那么在瀏覽器1中的A賬號將會被擠出去,當用戶操作瀏覽器1的頁面,頁面會跳到登錄頁面,需要重新登錄。那么我們怎么實現(xiàn)這樣的功能呢?下面將給大家進行詳細的介紹:
原理
用戶A使用賬號a在瀏覽器當中登錄,然后用戶B在另外一臺電腦上的瀏覽器登錄賬號a,當用戶B登錄驗證成功時,將會觸發(fā)登錄監(jiān)聽類,在監(jiān)聽類當中判斷出賬號a已經(jīng)被用戶A登錄,就把用戶A的賬號a 踢出去,此時當用戶A操作頁面,頁面就會跳轉到登錄頁面。
代碼實現(xiàn)
在實現(xiàn)過程中,用到LoginListenner監(jiān)聽類、login登錄方法以及在web.xml中配置監(jiān)聽類
LoginListenner
當?shù)卿洺晒?,向session中放入登錄成功的賬號對象loginuser,觸發(fā)LoginListenner中的attributeAdded事件,在這個事件中,我們判斷存放賬號和session對應關系的map中是否有當前登錄的賬號的session,如果有我們就把該session從map中移除,同時注銷該session,然后把剛登錄的賬號和session放入map。下面是代碼:
/**
*
* @ClassName: LoginListenner
* @Description: 登錄監(jiān)聽類-處理同一時間只允許賬號,單地點登錄
* @author mr_smile2014 605051929@qq.com
* @date 2014年11月12日 下午2:23:41
*
*/
public class LoginListenner implements HttpSessionAttributeListener {
/**
* 用于存放賬號和session對應關系的map
*/
private Map<String, HttpSession> map = new HashMap<String, HttpSession>();
/**
* 當向session中放入數(shù)據(jù)觸發(fā)
*/
public void attributeAdded(HttpSessionBindingEvent event) {
String name = event.getName();
if (name.equals("loginuser")) {
User user = (User) event.getValue();
if (map.get(user.getUserName()) != null) {
HttpSession session = map.get(user.getUserName());
session.removeAttribute(user.getUserName());
session.invalidate();
}
map.put(user.getUserName(), event.getSession());
}
}
/**
* 當向session中移除數(shù)據(jù)觸發(fā)
*/
public void attributeRemoved(HttpSessionBindingEvent event) {
String name = event.getName();
if (name.equals("loginuser")) {
User user = (User) event.getValue();
map.remove(user.getUserName());
}
}
public void attributeReplaced(HttpSessionBindingEvent event) {
}
public Map<String, HttpSession> getMap() {
return map;
}
public void setMap(Map<String, HttpSession> map) {
this.map = map;
}
}
登錄方法
對賬號、密碼、驗證碼進行判斷和驗證,驗證通過后把對應的用戶對象放入到session中,代碼如下:
/**
* 登錄
*
* @param userName
* @param passWord
* @param code
* 驗證碼
* @param type
* 登陸類型(商戶,操作員)
* @param model
* @return
*/
@RequestMapping("/login")
public String login(String account, String passWord, String code,
Model model, HttpServletRequest request) {
//登錄驗證并返回登錄成功用戶對象
User user=loginResult(userPhone, passWord, code, request);
//把用戶對象放入到session中,將會觸發(fā)LoginListenner中的attributeAdded事件
request.getSession().setAttribute("loginuser", user);
}
web.xml配置
把LoginListenner監(jiān)聽類,配置到web.xml文件中,這樣對session的監(jiān)聽才生效。配置如下:
<!--一個用戶只能在一個主機登錄 --> <listener> <listener-class>com.test.listenner.LoginListenner</listener-class> </listener>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
SpringBoot3實戰(zhàn)教程之實現(xiàn)接口簽名驗證功能
接口簽名是一種重要的安全機制,用于確保 API 請求的真實性、數(shù)據(jù)的完整性以及防止重放攻擊,這篇文章主要介紹了SpringBoot3實戰(zhàn)教程之實現(xiàn)接口簽名驗證功能,需要的朋友可以參考下2025-04-04
Java如何優(yōu)雅地關閉資源try-with-resource及其異常抑制
這篇文章主要介紹了Java如何優(yōu)雅地關閉資源try-with-resource及其異常抑制,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02

