From da247c61b715dafaba58e8dd4f106f0954f6cbf4 Mon Sep 17 00:00:00 2001 From: 疯狂的狮子Li <15040126243@163.com> Date: 星期四, 09 十二月 2021 16:32:32 +0800 Subject: [PATCH] update 过滤离线用户 --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/SysUserOnlineController.java | 15 +++++++++++---- 1 files changed, 11 insertions(+), 4 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 e1eaf2c..e8e2750 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; @@ -18,10 +19,10 @@ import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.RequiredArgsConstructor; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import java.util.ArrayList; -import java.util.Collection; import java.util.Collections; import java.util.List; import java.util.stream.Collectors; @@ -41,10 +42,16 @@ @SaCheckPermission("monitor:online:list") @GetMapping("/list") public TableDataInfo<SysUserOnline> list(String ipaddr, String userName) { - Collection<String> keys = RedisUtils.keys(Constants.ONLINE_TOKEN_KEY + "*"); + // 鑾峰彇鎵�鏈夋湭杩囨湡鐨� token + List<String> keys = StpUtil.searchTokenValue("", -1, 0); List<UserOnlineDTO> userOnlineDTOList = new ArrayList<>(); for (String key : keys) { - userOnlineDTOList.add(RedisUtils.getCacheObject(key)); + // 濡傛灉宸茬粡杩囨湡鍒欒涪涓嬬嚎 + if (StpUtil.stpLogic.getTokenActivityTimeoutByToken(key) < 0) { + continue; + } + String onlineKey = key.replace(Constants.LOGIN_TOKEN_KEY, Constants.ONLINE_TOKEN_KEY); + userOnlineDTOList.add(RedisUtils.getCacheObject(onlineKey)); } if (StringUtils.isNotEmpty(ipaddr) && StringUtils.isNotEmpty(userName)) { userOnlineDTOList = userOnlineDTOList.stream().filter(userOnline -> @@ -75,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