springboot+shiro中自定义session过期时间

在springboot工程中,使用shiro作为权限框架,并采用redis来管理session时,如何自定义session过期时间?
在这里插入图片描述
上面与会话或缓存相关的组件有:

  • Session Manager:会话管理器
  • Session DAO:会话 DAO,将session保存到数据库、缓存等
  • Cache Manager:缓存管理器,权限认证的缓存、用户及权限信息的缓存等
    若只是做session共享,只需添加SessionDAO即可,不过为了防止出现缓存不一致性的问题,也将数据一起共享,则自定义session方法如下:
  1. 设置SessionManager:sessionManager.setGlobalSessionTimeout(24 * 60 * 1000);//单位为毫秒
  2. 设置RedisSessionDAO:redisSessionDAO.setExpire(24 * 60);//单位为秒
  3. 设置RedisCacheManager:redisCacheManager.setExpire(24 * 60);//单位为秒

第一个是session会话时间,默认为1800000L,即30分钟;
在这里插入图片描述

第二个是redis存储的session有效时间,默认为-2,即与session过期时间相同;
在这里插入图片描述
在这里插入图片描述

第三个是redis存储的cache有效时间,默认为1800,即30分钟;
在这里插入图片描述
其他地方的session配置都不用管,主要是前两个决定session过期时间。

如何在登录时设置过期时间呢?
若是设置永不过期,在登陆最开始加上
SecurityUtils.getSubject().getSession().setTimeout(-1000L);其中时间单位毫秒;
若设置指定过期时间,如下
SecurityUtils.getSubject().getSession().setTimeout(1800 * 1000);
其实质是设置session的过期时间,Session接口的默认实现SimpleSession设置的默认时间为1800000L毫秒。
注意:单独在登录时设置过期时间或单独在SessionManager中设置过期时间都是生效的;若在登录时设置了过期时间,在SessionManager中也设置了过期时间时,无论是前者设置的过期时间大于后者,还是前者设置的过期时间小于后者,均是前者时间生效,前者设置的过期时间会覆盖后者的过期时间。

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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即可。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值