利用listener实现无法使用同一用户登陆多次

实现代码如下:

public class LoginSessionListener implements HttpSessionAttributeListener {  //通过实现此接口完成对session中的属性值变化监听
    
    private static final String LOGIN_USER="loginUser";

    @Override
    public void attributeAdded(HttpSessionBindingEvent hsbe) {
        String attrName = hsbe.getName();//监听到session属性值发生添加操作,获取对应操作的属性名
        
        if(LOGIN_USER.equals(attrName)){//若属性名为登录属性名,判定为用户登录操作
            String attrVal = (String)hsbe.getValue();//获取添加的属性值,即用户登录名
            HttpSession session = hsbe.getSession();//该次操作的session对象
            String sessionId = session.getId();//该次操作的session对象ID
            
            String sessionId2 = LoginCache.getInstance().getSessionIdByUsername(attrVal);//从缓存对象里面,获得该用户登录名对应的sessionID值
            if(null == sessionId2){//未获得结果,不需要清理前次登录用户会话信息
                
            }else{
                HttpSession session2 = LoginCache.getInstance().getSessionBySessionId(sessionId2);//获取前次该用户登录对应的session对象
                session2.invalidate();//清理前次登录用户会话存储信息,使得前次登录失效
            }
            
            //完成该次登录用户登录名、sessionID,session对象的缓存对象存储
            LoginCache.getInstance().setSessionIdByUserName(attrVal, sessionId);
            LoginCache.getInstance().setSessionBySessionId(sessionId, session);
            
        }

    }

    @Override
    public void attributeRemoved(HttpSessionBindingEvent arg0) {
        // TODO Auto-generated method stub

    }

    @Override
    public void attributeReplaced(HttpSessionBindingEvent arg0) {
        // TODO Auto-generated method stub

    }

}
原文地址:https://www.cnblogs.com/shouyaya/p/12064019.html