123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- package com.boman.system.controller;
- import java.util.*;
- import com.boman.common.core.utils.SecurityUtils;
- import com.boman.domain.SysUser;
- import com.boman.system.service.ISysUserService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.DeleteMapping;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.PathVariable;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RestController;
- import com.boman.domain.constant.CacheConstants;
- import com.boman.common.core.utils.StringUtils;
- import com.boman.common.core.web.controller.BaseController;
- import com.boman.domain.dto.AjaxResult;
- import com.boman.domain.TableDataInfo;
- import com.boman.common.log.annotation.Log;
- import com.boman.common.log.enums.BusinessType;
- import com.boman.common.redis.service.RedisService;
- import com.boman.common.security.annotation.PreAuthorize;
- import com.boman.system.api.model.LoginUser;
- import com.boman.system.domain.SysUserOnline;
- import com.boman.system.service.ISysUserOnlineService;
- /**
- * 在线用户监控
- *
- * @author ruoyi
- */
- @RestController
- @RequestMapping("/online")
- public class SysUserOnlineController extends BaseController
- {
- @Autowired
- private ISysUserOnlineService userOnlineService;
- @Autowired
- private RedisService redisService;
- @Autowired
- private ISysUserService sysUserService;
- @GetMapping("/onlineNum")
- public AjaxResult onlineNum()
- {
- Collection<String> keys = redisService.keys(CacheConstants.LOGIN_TOKEN_KEY + "*");
- Map<String,Object> map = new HashMap<>();
- int allCount = sysUserService.selectUserListAllCount();
- map.put("onlineNum",keys.size());
- map.put("allCount",allCount);
- // 获取当前的用户信息
- LoginUser user = redisService.getCacheObject(CacheConstants.LOGIN_TOKEN_KEY + SecurityUtils.getToken());
- Set<String> roles = user.getRoles();
- map.put("roles",roles);
- return AjaxResult.success(map);
- }
- @PreAuthorize(hasPermi = "monitor:online:list")
- @GetMapping("/list")
- public TableDataInfo list(String ipaddr, String userName)
- {
- Collection<String> keys = redisService.keys(CacheConstants.LOGIN_TOKEN_KEY + "*");
- List<SysUserOnline> userOnlineList = new ArrayList<SysUserOnline>();
- for (String key : keys)
- {
- LoginUser user = redisService.getCacheObject(key);
- if (StringUtils.isNotEmpty(ipaddr) && StringUtils.isNotEmpty(userName))
- {
- if (StringUtils.equals(ipaddr, user.getIpaddr()) && StringUtils.equals(userName, user.getUsername()))
- {
- userOnlineList.add(userOnlineService.selectOnlineByInfo(ipaddr, userName, user));
- }
- }
- else if (StringUtils.isNotEmpty(ipaddr))
- {
- if (StringUtils.equals(ipaddr, user.getIpaddr()))
- {
- userOnlineList.add(userOnlineService.selectOnlineByIpaddr(ipaddr, user));
- }
- }
- else if (StringUtils.isNotEmpty(userName))
- {
- if (StringUtils.equals(userName, user.getUsername()))
- {
- userOnlineList.add(userOnlineService.selectOnlineByUserName(userName, user));
- }
- }
- else
- {
- userOnlineList.add(userOnlineService.loginUserToUserOnline(user));
- }
- }
- Collections.reverse(userOnlineList);
- userOnlineList.removeAll(Collections.singleton(null));
- return getDataTable(userOnlineList);
- }
- /**
- * 强退用户
- */
- @PreAuthorize(hasPermi = "monitor:online:forceLogout")
- @Log(title = "在线用户", businessType = BusinessType.FORCE)
- @DeleteMapping("/{tokenId}")
- public AjaxResult forceLogout(@PathVariable String tokenId)
- {
- redisService.deleteObject(CacheConstants.LOGIN_TOKEN_KEY + tokenId);
- return AjaxResult.success();
- }
- }
|