SpringSecurity :解决多端登录没有踢下线

此处有巨坑

问题描述

使用数据库中的用户数据进行登录验证,配置好maximumSessions(1),使用多个浏览器登录同个账号,发现全都可以登陆,先登录的客户端也不会被挤下线。

先说解决方法:

  1. 自己的User类必须重写两个方法:继承自Object类的hashCode() 和 equals()
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        User user = (User) o;
        return Objects.equals(username, user.username);
    }
    
    @Override
    public int hashCode() {
        return Objects.hash(username);
    }

     

  2. 配置文件中,参数为http那个configure中:
    http.sessionManagement().maximumSessions(1).expiredSessionStrategy(sessionExpired);
    

    **就这么两步,如果是使用内存中的用户或者使用Security自带的那个User类来封装用户名密码的话,只需要第二步,开箱即用。

原因排查

使用debug,从获取request中的用户名开始跟踪,发现所有的Session都是由org.spri

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值