From f7664a2d7e758578f7f5d7c909001883053628fd Mon Sep 17 00:00:00 2001
From: 疯狂的狮子Li <15040126243@163.com>
Date: 星期四, 09 十二月 2021 16:08:18 +0800
Subject: [PATCH] update 查询在线用户检查是否已经离线 如果离线则清除token

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/SysUserOnlineController.java |    7 ++++++-
 1 files changed, 6 insertions(+), 1 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/SysUserOnlineController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/SysUserOnlineController.java
index 529d5e7..87400d6 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/SysUserOnlineController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/SysUserOnlineController.java
@@ -2,6 +2,7 @@
 
 import cn.dev33.satoken.annotation.SaCheckPermission;
 import cn.dev33.satoken.exception.NotLoginException;
+import cn.dev33.satoken.stp.StpLogic;
 import cn.dev33.satoken.stp.StpUtil;
 import cn.hutool.core.bean.BeanUtil;
 import com.ruoyi.common.annotation.Log;
@@ -45,6 +46,10 @@
         List<String> keys = StpUtil.searchTokenValue("", -1, 0);
         List<UserOnlineDTO> userOnlineDTOList = new ArrayList<>();
         for (String key : keys) {
+            // 濡傛灉宸茬粡杩囨湡鍒欒涪涓嬬嚎
+            if (StpUtil.stpLogic.getTokenActivityTimeoutByToken(key) < 0) {
+                StpUtil.kickoutByTokenValue(key);
+            }
             String onlineKey = key.replace(Constants.LOGIN_TOKEN_KEY, Constants.ONLINE_TOKEN_KEY);
             userOnlineDTOList.add(RedisUtils.getCacheObject(onlineKey));
         }
@@ -77,7 +82,7 @@
     @DeleteMapping("/{tokenId}")
     public AjaxResult<Void> forceLogout(@PathVariable String tokenId) {
         try {
-            StpUtil.logoutByTokenValue(tokenId);
+            StpUtil.kickoutByTokenValue(tokenId);
         } catch (NotLoginException e) {
         }
         return AjaxResult.success();

--
Gitblit v1.9.3