解决用户只允许在一处地方登陆其他地方登陆踢掉
在登录完成的时候直接把用户的登录时间记录到用户对象里面 然后把用户放到一个静态的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;
}