使用SessionListener+持久化Session+Springmvc拦截器实现单点登录

最近在研究springmvc中注册、登录的逻辑。在登录过程中session的管理是一个很重要的内容。分为下面的四种情况。

1. 单用户多点登录+非集群环境

         直接使用系统的session,将session写入的内存中

2. 单用户多点登录+集群环境

         要使用memcache或redis

3. 单用户单点登录+非集群环境

         自己持久化一个对象作为session,并维护

4. 单用户单点登录+集群环境

         要使用memcache或redis

 

这篇文章以及代码来实现非集群环境下的单点登录以及多点登录

思路:

传统session使用方法:服务器生成的session是放在内存中的,通过addAttribute向内存中的Session对象添加Object,给浏览器以cookie形式返回sessionid。

持久化session:把session的信息抽象为一个自定义对象userSessionStatus,放到我们自定义的数据结构里面

使用两个数据结构

singleUserList<Long,String>其中key为user-id,Value为sessionId

SessionStatusMap<String,Object>,其中key为sessionId,value为userSessionStatus

 

逻辑如下:

1. 在config.properties中,设置单点登录的标识is.single

 

2. web.xml配置session监听,以及session过期时间

 

3. 在sessionListener的sessionDestroy方法中,session正常过期时,从这两个数据数据结构中删除对应的数据

 

4. 当用户登录的时候,会执行addOrUpdataSessionStatusMap方法

在这个方法中,会调用SessionManager的putStatus方法,将userSessionStatus放到我们的这两个数据结构中。

在SessionManager中读取config.properties的is.single属性。

如果为true,单点登录模式,那么:

如果singleUserList中有这个userId,那么就将对应项从这两个数据结构中删除,并添加新的数据到这两个数据结构;否则就直接添加数据到这两个数据结构中。

如果为false,多点登录模式,那么不使用singleUserMap,直接将数据添加到SessionStatusMap中。

 

5. 写一个拦截器,LoginInteceptor,这个拦截器对exceptUrls以外的访问地址进行拦截,获取SessionStatusMap中的值。

如果存在,就放行。

如果不存在,就跳转到登录页面

 

6. 最后,session如果正常过期了,那么就从这两个数据数据结构中删除对应的数据

 

整个过程形成一个闭环。

项目结构如下:


代码比较多,需要的coder可以在此下载:http://download.csdn.net/download/u013905744/10038248 ,互相交流

代码里面数据库文件未包括,其实就是一个简单的t_user表,id自增Integer,username,password以及phone都是String

关于集群环境下的实现,在此留坑

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Shiro中,判断session是否失效可以通过以下代码实现: ```java Subject subject = SecurityUtils.getSubject(); if (subject != null) { Session session = subject.getSession(false); if (session == null) { // session已经失效 } } ``` 上述代码中,首先通过`SecurityUtils.getSubject()`获取`Subject`对象,再通过`subject.getSession(false)`获取当前用户的`Session`对象,如果返回值为`null`,则表示`Session`已经失效。 当然,也可以通过在Shiro配置文件中配置`sessionManager`,设置`sessionValidationSchedulerEnabled`参数为`true`,开启Shiro的`Session`定期检查功能,实现自动检测`Session`是否失效。 另外,在Spring Boot中集成Shiro时,可以通过实现`SessionListener`接口,监听`Session`的创建、销毁和过期事件,并在事件触发时执行相应的操作。具体可参考以下代码示例: ```java @Component public class MySessionListener implements SessionListener { @Override public void onStart(Session session) { // Session创建时触发 } @Override public void onStop(Session session) { // Session销毁时触发 } @Override public void onExpiration(Session session) { // Session过期时触发 } } ``` 在以上代码中,实现了`SessionListener`接口,并在各个方法中编写相应的操作代码,以实现对`Session`的监听。最后,在Spring Boot配置文件中配置`shiro.sessionListeners`参数,将自定义的`SessionListener`注册到Shiro中即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值