防止同一用户在不同地方下登陆的简单实现

基本的实现原理很简单,就是通过检测当前登陆请求的session是否为已登录状态的session,如果不是的话,说明你的账号在另一个地方登陆,这样会将之前登陆的账号踢下线,本质的操作就是,被踢出下线的请求会执行session.invalidate()。这种操作不能防止第二个用户是恶意登陆的,只是单纯的只允许一个在线的session。大家如果有什么更好的方案,希望提出来,一起进步学习。

1、每次登陆的时候会在数据库中插入用户此次登录的sessionid

user.setSessionid(session.getId());
this.userService.save(user);//将登录用户的sessionid存入到数据库

2、踢出用户下线的操作,可以在过滤器中完成,当用户访问需要登录权限的网页时,从数据库中拿出此用户上一步保存的sessionid,与当前内存中的sessionid作对比,如果不一样的话,说明这是此用户在第二次登陆了,数据库中的sessionid已经被第二次登陆更新了,当然此时不考虑session过期的情况。此时要做的操作很简单,即 session.invalidate();这里的情况时,自己虽然下线了,但是并不会影响第二次登陆的使用。

User user = (User) this.request.getSession().getAttribute(Constants.SESSION_USER);
HttpSession session = request.getSession();
if (user != null && null == user.getId()){
    session.invalidate();
    return null;
}
User ruser =null;
if(user!=null) {
    try {
        ruser = this.userService.findByUserName(HtmlUtils.htmlEscape(user.getUsername()));
    } catch (Exception e) {
        e.printStackTrace();
    }
    if (!session.getId().equals(ruser.getSessionid())) {
        session.invalidate();
    	return null;
    }
}
return user;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值