解决shiro 定时监听器不生效的问题 onExpiration不调用问题

 更新时间:2021年07月29日 11:44:58   作者:Mitnickl  
这篇文章主要介绍了解决shiro 定时监听器不生效的问题 onExpiration不调用问题。具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

问题

redis 抛出异常:

redis.clients.jedis.ScanResult.getStringCursor()Ljava/lang/String;
Method threw 'java.lang.NoSuchMethodError' exception.

说明

spring-boot 版本

 <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.5</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

shiro-redis版本

 <dependency>
   <groupId>org.crazycake</groupId>
   <artifactId>shiro-redis</artifactId>
   <version>3.2.3</version>
</dependency>

jedis版本

image-20210721141755093

shiro设置定时检测session失效

shiro配置session失效时间,没有引用shiro-quartz ,采用默认的

ExecutorServiceSessionValidationScheduler

shiro 配置

  @Bean
    public SessionManager sessionManager(SimpleCookie simpleCookie, SessionDAO sessionDAO) {
        logger.debug("安全框架配置:开始sessionManager配置");
        SkySessionManager skySessionManager = new SkySessionManager();
        skySessionManager.setSessionDAO(sessionDAO);
        skySessionManager.setSessionIdCookie(simpleCookie);
        // 开启cookie
        skySessionManager.setSessionIdCookieEnabled(true);
        // session 失效删除session
        skySessionManager.setDeleteInvalidSessions(true);
        // 定期检查 失效的 session
        skySessionManager.setSessionValidationInterval(10000);
        // 开启 schedule
        skySessionManager.setSessionValidationSchedulerEnabled(true);
​
        skySessionManager.setSessionListeners(Collections.singletonList(new SkySessionListener()));
        logger.debug("安全框架配置:结束sessionManager配置");
        return skySessionManager;
    }

shiro schedule 创建逻辑

问题出现点

当创建完默认的scheduler 后会执行一次 run方法。

继续跟踪代码

发现 此处有异常,但是异常并未被捕获,导致线程中断。

网上百度此异常 说是,jedis版本不一致导致。

解决方案

查看shiro-redis pom文件jedis的版本号。

image-20210721142036883

发现jedis版本号为2.9.0

将jedis 2.9.0 集成进项目:

<dependency>
  <groupId>redis.clients</groupId>
  <artifactId>jedis</artifactId>
  <version>2.9.0</version>
</dependency>

至此问题解决。

 @Override
public void onExpiration(Session session)

onExpiration 方法不调用的问题, 此方法是通过上面的定时任务提醒来进行触发的。

由于,redis 和ehcache 本身设置了过期时间,过期之后 session 变从 redis 后者ehcache 里面删除,因此 onExpiration 过期之后此方法 永远不会被调用到。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 详解Java弱引用(WeakReference)的理解与使用

    详解Java弱引用(WeakReference)的理解与使用

    这篇文章主要介绍了Java弱引用(WeakReference)的理解与使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • Java OpenCV图像处理之背景切换

    Java OpenCV图像处理之背景切换

    这篇文章主要介绍了利用Java OpenCV实现图像背景的切换,文中的示例代码讲解详细。对我们学习OpenCV有一定帮助,感兴趣的同学可以了解一下
    2022-01-01
  • Java中Finally关键字

    Java中Finally关键字

    与其他语言的模型相比,finally 关键字是对 Java 异常处理模型的最佳补充。接下来通过本文给大家介绍Java中Finally关键字及finally关键字的使用相关知识,感兴趣的朋友一起学习吧
    2016-05-05
  • SpringBoot整合SpringSecurity和JWT的示例

    SpringBoot整合SpringSecurity和JWT的示例

    这篇文章主要介绍了SpringBoot整合SpringSecurity和JWT的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • java实现二维码生成的几个方法(推荐)

    java实现二维码生成的几个方法(推荐)

    本篇文章主要介绍了java实现二维码生成的几个方法(推荐),具有一定的参考价值,有兴趣的可以了解一下。
    2016-12-12
  • 浅谈Redis在微服务架构中的几种应用场景

    浅谈Redis在微服务架构中的几种应用场景

    本文介绍在SpringCloud中使用Redis作为Pub/Sub异步通信、缓存或主数据库和配置服务器的三种场景应用。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-05-05
  • 一篇文章带你使用SpringBoot基于WebSocket的在线群聊实现

    一篇文章带你使用SpringBoot基于WebSocket的在线群聊实现

    这篇文章主要介绍了一篇文章带你使用SpringBoot基于WebSocket的在线群聊实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • Spring整合Mybatis详细步骤

    Spring整合Mybatis详细步骤

    今天带大家来学习Spring怎么整合Mybatis,文中有非常详细的代码示例及介绍,对正在学习java的小伙伴们有很好地帮助,需要的朋友可以参考下
    2021-05-05
  • Windows安装两个或多个JDK并实现自由切换的方法

    Windows安装两个或多个JDK并实现自由切换的方法

    最近新接手一个项目,启动的时候,发现有些jar和现在正在使用的JDK版本不一致,一直启动有问题,想着就多装一个JDK,由于为了保证java的运行环境和编译环境保持一致,就需要我们设置jdk的环境变量,所以本文给大家介绍了Windows安装两个或多个JDK并实现自由切换的方法
    2025-03-03
  • SpringBoot之Java配置的实现

    SpringBoot之Java配置的实现

    这篇文章主要介绍了SpringBoot之Java配置的实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01

最新评论