From 16427ab3e7335fb6242699ee4afb9881dfd13439 Mon Sep 17 00:00:00 2001
From: huliguo <2023611923@qq.com>
Date: 星期三, 30 四月 2025 17:10:02 +0800
Subject: [PATCH] 过期token定时清理

---
 src/main/java/com/cl/service/impl/TokenBlacklistService.java |   30 ++++++++++++++++++++++++++++++
 1 files changed, 30 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/cl/service/impl/TokenBlacklistService.java b/src/main/java/com/cl/service/impl/TokenBlacklistService.java
index 0db2a84..d077d07 100644
--- a/src/main/java/com/cl/service/impl/TokenBlacklistService.java
+++ b/src/main/java/com/cl/service/impl/TokenBlacklistService.java
@@ -1,15 +1,22 @@
 package com.cl.service.impl;
 
 
+import com.cl.util.JwtUtil;
+import io.jsonwebtoken.Claims;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Service;
 
 import java.util.Collections;
 
+import java.util.Date;
 import java.util.Set;
 import java.util.concurrent.ConcurrentHashMap;
+import java.util.concurrent.TimeUnit;
 
 
 @Service
+@Slf4j
 public class TokenBlacklistService {
     // 使用ConcurrentHashMap或Redis存储黑名单
     private final Set<String> blacklist = Collections.newSetFromMap(new ConcurrentHashMap<>());
@@ -22,4 +29,27 @@
         return blacklist.contains(token);
     }
 
+
+    /**
+     * 定时清理过期令牌(每2小时执行一次)
+     */
+    @Scheduled(fixedRate = 2, timeUnit = TimeUnit.HOURS)
+    public void cleanupExpiredTokens() {
+        log.info("开始清理过期token");
+        blacklist.removeIf(this::isTokenExpired);
+    }
+    /**
+     * 检查JWT Token是否过期
+     * @param token JWT Token字符串
+     * @return true-已过期,false-未过期
+     */
+    public boolean isTokenExpired(String token) {
+        try {
+            Claims claims = JwtUtil.parseJWT(token);
+            return claims.getExpiration().before(new Date());
+        } catch (Exception e) {
+            // 如果解析过程中出现异常(如Token无效、已过期等),视为已过期
+            return true;
+        }
+    }
 }
\ No newline at end of file

--
Gitblit v1.7.1