用户唯一登录

解决用户只允许在一处地方登陆其他地方登陆踢掉 

在登录完成的时候直接把用户的登录时间记录到用户对象里面 然后把用户放到一个静态的map 里面  已用户的id 为key 用户实体为value

每次登录替换map 里面的user 如果第一个地方已经登录了 然后第二处再去登录这时候map里面的用户的登录时间已经改变然后第一处的用户session 的登录时间没有改变这时候可以剔除第一处登录地方。

private static Map<String, User> UserList = new HashMap<String, User>();


public static void addAttr(User u) {
User user = (User) UserList.get(u.getName());
if (user != null && user.equals(u)) {
UserList.remove(user.getName());
}
UserList.put(u.getName(), u);
}

登陆后更新用户登录时间和替换map里面的用户代码

u.setLoginTime(new Date());
u.setName(username);
UserList.addAttr(u);


每次请求的时候都去校验当前session用户的登录时间和map里面的用户的登录时间是否一致  这里可以用拦截器 具体的业务可以自己具体分析

拦截器代码。。。

Controller controller = inv.getController();
User u = Constants.getLoginUser(controller.getSession());
if (!IsNullOrEmpty.isNullOrEmpty(u)) {
if(UserList.isOldUser(u)){
String message = "您的帐号在别的地方登录,您已被迫退出。请注意保护您的密码!";

}


/**
* 根据登录时间判断登录次序的先后

* @param User
* @return
*/
public static boolean isOldUser(User u) {
User user = (User) UserList.get(u.getName());
if (user != null) {
Date loginTime = user.getLoginTime();
if (!u.getLoginTime().equals(loginTime)) {
return true;
}
} else {
return true;
}


return false;
}

原文地址:https://www.cnblogs.com/root429/p/9251393.html