JavaWeb如何實現(xiàn)限制單個賬號多處登錄
在網上有很多解決限制登錄的方法,包括SpringSecurity也有解決的方案,今天記錄一下使用JavaWeb的實現(xiàn)
知識點
思路如下:

演示
具體實現(xiàn):
1.維護一個map集合
public class LoginUserMap {
private static Map<String, String> loginUserMap = new ConcurrentHashMap<String, String>();
/**
* set方法
*
* @param loginId 用戶唯一標識,用戶名或者用戶Id
* @param sessionId sessionId
*/
public static void setLoginUserMap(String loginId, String sessionId) {
loginUserMap.put(loginId, sessionId);
}
/**
* get方法
*
* @return
*/
public static Map<String, String> getLoginUserMap() {
return loginUserMap;
}
/**
* 根據sessionId移除map中的值
*
* @param sessionId
*/
public static void removeUser(String sessionId) {
for (Map.Entry<String, String> entry : loginUserMap.entrySet()) {
if (sessionId.equals(entry.getValue())) {
loginUserMap.remove(entry.getKey());
break;
}
}
}
/**
* 判斷用戶是否在map中
*
* @param loginId
* @param sessionId
* @return
*/
public static boolean isInLoginUsers(String loginId, String sessionId) {
return (loginUserMap.containsKey(loginId) && sessionId.equals(loginUserMap.get(loginId)));
}
2.實現(xiàn)一個session監(jiān)聽
session銷毀能及時更新map
@WebListener
public class SessionListener implements HttpSessionListener {
private Logger logger=LoggerFactory.getLogger(SessionListener.class);
@Override
public void sessionCreated(HttpSessionEvent httpSessionEvent) {
}
@Override
public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
HttpSession session = httpSessionEvent.getSession();
String sessionId = session.getId();
//session銷毀時消除loginUserMap中的sessionId
LoginUserMap.removeUser(sessionId);
logger.info("session銷毀,sessionId:"+sessionId);
}
}3.定義過濾器
可自定義一個過濾器,但要排除登錄請求(略),核心代碼如下
//判斷是否重復登錄
String loginName = username.getLoginName();//獲取用戶唯一標識
//判斷當前用戶session是否改變
if (!LoginUserMap.isInLoginUsers(loginName,session.getId())) {
//定義自己的實現(xiàn)方式,被擠下線,我的是:
//session發(fā)送改變,表示別處登錄
//被擠下線,清除session,提示信息,實現(xiàn)跳轉
request.setAttribute("online",false);
request.getRequestDispatcher("/logout.do").forward(request,response);
return;
}
chain.doFilter(new XssHttpSerlet((HttpServletRequest) request), response);4.注冊監(jiān)聽和過濾器
<filter>
<filter-name>LoginLimitFilter</filter-name>
<filter-class>io.github.brightloong.loginlimite.LoginLimitFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>LoginLimitFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>另外,可以設置輪詢的方式判斷,讓用戶及時下線,但消耗資源,我采取的是請求失敗跳轉的方式,直接調用退出登錄的接口
總結
實現(xiàn)無法解決同一瀏覽器多次登錄的問題,及sessionId相同,但能實現(xiàn)基本的限制登錄的操作,因為做的是踢線下,所以相比賬號在線,無法登錄來說,稍微簡單,若做第二種形式,則需要考慮session是否消除的問題。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
org.springframework.dao.OptimisticLockingFailureException樂觀鎖
本文主要介紹了org.springframework.dao.OptimisticLockingFailureException樂觀鎖失敗的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-05-05
java ThreadLocal線程局部變量常用方法使用場景示例詳解
這篇文章主要介紹了為大家java ThreadLocal線程局部變量常用方法使用場景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07
springboot的實體類字段校驗的分組校驗具體實現(xiàn)步驟
分組校驗允許在不同場景下對同一實體類應用不同的校驗規(guī)則,通過定義分組接口、在實體類和Controller中指定分組,以及全局異常處理,可以靈活控制校驗規(guī)則,本文介紹springboot的實體類字段校驗的分組校驗,感興趣的朋友一起看看吧2025-03-03
Spring Boot集成starrocks快速入門Demo(適用場景)
StarRocks 是新一代極速全場景 MPP (Massively Parallel Processing) 數(shù)據庫,StarRocks 的愿景是能夠讓用戶的數(shù)據分析變得更加簡單和敏捷,這篇文章主要介紹了Spring Boot集成starrocks快速入門Demo,需要的朋友可以參考下2024-08-08

