溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何解決shiro定時監(jiān)聽器不生效的問題

發(fā)布時間:2021-07-29 16:35:29 來源:億速云 閱讀:146 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要講解了“如何解決shiro定時監(jiān)聽器不生效的問題”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“如何解決shiro定時監(jiān)聽器不生效的問題”吧!

問題

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版本

如何解決shiro定時監(jiān)聽器不生效的問題

shiro設(shè)置定時檢測session失效

shiro配置session失效時間,沒有引用shiro-quartz ,采用默認(rèn)的

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("安全框架配置:結(jié)束sessionManager配置");
        return skySessionManager;
    }

shiro schedule 創(chuàng)建邏輯

如何解決shiro定時監(jiān)聽器不生效的問題

如何解決shiro定時監(jiān)聽器不生效的問題

如何解決shiro定時監(jiān)聽器不生效的問題

如何解決shiro定時監(jiān)聽器不生效的問題

問題出現(xiàn)點(diǎn)

當(dāng)創(chuàng)建完默認(rèn)的scheduler 后會執(zhí)行一次 run方法。

如何解決shiro定時監(jiān)聽器不生效的問題

繼續(xù)跟蹤代碼

如何解決shiro定時監(jiān)聽器不生效的問題

發(fā)現(xiàn) 此處有異常,但是異常并未被捕獲,導(dǎo)致線程中斷。

網(wǎng)上百度此異常 說是,jedis版本不一致導(dǎo)致。

解決方案

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

如何解決shiro定時監(jiān)聽器不生效的問題

發(fā)現(xiàn)jedis版本號為2.9.0

將jedis 2.9.0 集成進(jìn)項(xiàng)目:

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

至此問題解決。

 @Override
public void onExpiration(Session session)

onExpiration 方法不調(diào)用的問題, 此方法是通過上面的定時任務(wù)提醒來進(jìn)行觸發(fā)的。

如何解決shiro定時監(jiān)聽器不生效的問題

由于,redis 和ehcache 本身設(shè)置了過期時間,過期之后 session 變從 redis 后者ehcache 里面刪除,因此 onExpiration 過期之后此方法 永遠(yuǎn)不會被調(diào)用到。

感謝各位的閱讀,以上就是“如何解決shiro定時監(jiān)聽器不生效的問題”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對如何解決shiro定時監(jiān)聽器不生效的問題這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI