|
@@ -1,19 +1,23 @@
|
|
|
package com.huashe.park.application.web.controller.monitor;
|
|
|
|
|
|
+import com.huashe.common.constant.CacheConstants;
|
|
|
+import com.huashe.common.domain.AjaxResult;
|
|
|
+import com.huashe.common.utils.StringUtils;
|
|
|
import com.ruoyi.common.annotation.Log;
|
|
|
-import com.ruoyi.common.constant.CacheConstants;
|
|
|
import com.ruoyi.common.core.controller.BaseController;
|
|
|
-import com.ruoyi.common.core.domain.AjaxResult;
|
|
|
import com.ruoyi.common.core.domain.model.LoginUser;
|
|
|
import com.ruoyi.common.core.page.TableDataInfo;
|
|
|
import com.ruoyi.common.core.redis.RedisCache;
|
|
|
import com.ruoyi.common.enums.BusinessType;
|
|
|
-import com.ruoyi.common.utils.StringUtils;
|
|
|
import com.ruoyi.system.domain.SysUserOnline;
|
|
|
import com.ruoyi.system.service.ISysUserOnlineService;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.security.access.prepost.PreAuthorize;
|
|
|
-import org.springframework.web.bind.annotation.*;
|
|
|
+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 java.util.ArrayList;
|
|
|
import java.util.Collection;
|
|
@@ -22,13 +26,12 @@ import java.util.List;
|
|
|
|
|
|
/**
|
|
|
* 在线用户监控
|
|
|
- *
|
|
|
+ *
|
|
|
* @author ruoyi
|
|
|
*/
|
|
|
@RestController
|
|
|
@RequestMapping("/monitor/online")
|
|
|
-public class SysUserOnlineController extends BaseController
|
|
|
-{
|
|
|
+public class SysUserOnlineController extends BaseController {
|
|
|
@Autowired
|
|
|
private ISysUserOnlineService userOnlineService;
|
|
|
|
|
@@ -37,27 +40,18 @@ public class SysUserOnlineController extends BaseController
|
|
|
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:online:list')")
|
|
|
@GetMapping("/list")
|
|
|
- public TableDataInfo list(String ipaddr, String userName)
|
|
|
- {
|
|
|
+ public TableDataInfo list(String ipaddr, String userName) {
|
|
|
Collection<String> keys = redisCache.keys(CacheConstants.LOGIN_TOKEN_KEY + "*");
|
|
|
List<SysUserOnline> userOnlineList = new ArrayList<SysUserOnline>();
|
|
|
- for (String key : keys)
|
|
|
- {
|
|
|
+ for (String key : keys) {
|
|
|
LoginUser user = redisCache.getCacheObject(key);
|
|
|
- if (StringUtils.isNotEmpty(ipaddr) && StringUtils.isNotEmpty(userName))
|
|
|
- {
|
|
|
+ if (StringUtils.isNotEmpty(ipaddr) && StringUtils.isNotEmpty(userName)) {
|
|
|
userOnlineList.add(userOnlineService.selectOnlineByInfo(ipaddr, userName, user));
|
|
|
- }
|
|
|
- else if (StringUtils.isNotEmpty(ipaddr))
|
|
|
- {
|
|
|
+ } else if (StringUtils.isNotEmpty(ipaddr)) {
|
|
|
userOnlineList.add(userOnlineService.selectOnlineByIpaddr(ipaddr, user));
|
|
|
- }
|
|
|
- else if (StringUtils.isNotEmpty(userName) && StringUtils.isNotNull(user.getUser()))
|
|
|
- {
|
|
|
+ } else if (StringUtils.isNotEmpty(userName) && StringUtils.isNotNull(user.getUser())) {
|
|
|
userOnlineList.add(userOnlineService.selectOnlineByUserName(userName, user));
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
+ } else {
|
|
|
userOnlineList.add(userOnlineService.loginUserToUserOnline(user));
|
|
|
}
|
|
|
}
|
|
@@ -72,8 +66,7 @@ public class SysUserOnlineController extends BaseController
|
|
|
@PreAuthorize("@ss.hasPermi('monitor:online:forceLogout')")
|
|
|
@Log(title = "在线用户", businessType = BusinessType.FORCE)
|
|
|
@DeleteMapping("/{tokenId}")
|
|
|
- public AjaxResult forceLogout(@PathVariable String tokenId)
|
|
|
- {
|
|
|
+ public AjaxResult forceLogout(@PathVariable String tokenId) {
|
|
|
redisCache.deleteObject(CacheConstants.LOGIN_TOKEN_KEY + tokenId);
|
|
|
return success();
|
|
|
}
|