一、需求效果:

就是进入首页时能查看在线人数,没有特定要求,那我就不刷这个接口了

就进入首页加载一次

二、实现思路:

思路参考博客:

https://blog.csdn.net/GitLuckyd/article/details/124488063

如果是以前那种JSP的单体项目,可以用Servlet的监听器API来做

但是不管是Servlet还是现在微服务也好,没办法准确知道用户是否离开了应用

然后上面的思路是:

- 后台定时清空令牌容器

- 前端定时存入令牌,打一个时间差

- 只要存活的用户,不管是操作还是干嘛,只要没有关闭应用,就会持续存入令牌

三、代码实现:

后台接口直接做一个令牌容器

两个接口,一个查询容器令牌个数,一个存入令牌

package cn.ymcd.portal.user.controller;

import cn.ymcd.comm.log.LogFactory;
import cn.ymcd.comm.log.YmcdLogger;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController; import java.util.HashSet;
import java.util.Set; /**
* @author OnCloud9
* @version 1.0
* @project portal-app
* @date 2023年10月10日 14:46
*/
@RestController
@RequestMapping("${api.path}/online")
public class UserOnlineCountController {
private YmcdLogger logger = LogFactory.getLogger(this.getClass());
private static final Set<String> TOKEN_SETS = new HashSet<>(); /**
* @author OnCloud9
* @date 2023/10/8 11:34
* @description 获取在线人员数量
* @params []
* @return java.lang.Integer
*/
@GetMapping("/counts")
public Integer getOnlineCounts() {
return TOKEN_SETS.size();
} /**
* @author OnCloud9
* @date 2023/10/10 14:51
* @description 心跳接口, 前端调用接口定时添加令牌 3分钟一次
* @params [token]
* @return void
*/
@GetMapping("/heart-beat")
public void heartBeatTokenSet(@RequestParam("token") String token) {
TOKEN_SETS.add(token);
} /**
* @author OnCloud9
* @date 2023/10/10 14:55
* @description 清除令牌 每30分钟执行一次
* @params []
* @return void
*/
@Scheduled(cron = "0 0/30 * * * ?")
public void scheduledTasks() {
logger.info("cn.ymcd.portal.user.controller.UserOnlineCountController 开始清理用户令牌... 当前令牌信息:" + TOKEN_SETS.toString());
TOKEN_SETS.clear();
}
}

  

前端API接口:

/**
* 获取用户在线人数
* @returns {*}
*/
export function getOnlineCounts() {
return requestPortal({
url: 'online/counts',
method: 'get'
})
} /**
* 用户在线人数心跳接口
* @returns {*}
*/
export function onlineHeartBeats(token) {
return requestPortal({
url: 'online/heart-beat',
method: 'get',
params: { token }
})
}

首页的定时任务:

import { mapGetters } from 'vuex'
import { getOnlineCounts, onlineHeartBeats } from '../api/user'
computed: {
... mapGetters([
'name',
'roles',
'dept',
'userId',
'token'
])
},
created() {
getOnlineCounts().then(res => (this.onlineCounts = res.data)) /* 每三分钟心跳一次,刷新这个页面加载一次 */
onlineHeartBeats(this.token)
this.heartbeatInterval = setInterval(() => (onlineHeartBeats(this.token)), 1000 * 60 * 3)
},
beforeDestroy() {
clearInterval(this.heartbeatInterval)
}

  

【Java】用户在线人数统计的简单实现的更多相关文章

  1. Java用户输入数值,做简单的猜数字游戏,导入基础的工具包util

    Java用户输入数值,做简单的猜数字游戏,导入基础的工具包util,导入包的方法为,import java.util.*: 完整的实例代码: /* 导入基础工具包 */ import java.uti ...

  2. 用HttpSessionListener与HttpSessionBindingListener实现在线人数统计

    在线人数统计方面的实现,最初我的想法是,管理session,如果session销毁了就减少,如果登陆用户了就新增一个,但是如果是用户非法退出,如:未注销,关闭浏览器等,这个用户的session是管理不 ...

  3. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(40)-精准在线人数统计实现-【过滤器+Cache】

    原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(40)-精准在线人数统计实现-[过滤器+Cache] 系列目录 上次的探讨没有任何结果,我浏览了大量的文章 ...

  4. HttpsessionListener 实现在线人数统计

    最近在学servlet jsp,用的林信良先生的 jsp&servlet 这本书,在第五章有道在线人数统计的课后题完成,做一次记录. 实际效果: 一:用户类: package cc.openh ...

  5. Java静态检测工具/Java代码规范和质量检查简单介绍(转)

    静态检查: 静态测试包括代码检查.静态结构分析.代码质量度量等.它可以由人工进行,充分发挥人的逻辑思维优势,也可以借助软件工具自动进行.代码检查代码检查包括代码走查.桌面检查.代码审查等,主要检查代码 ...

  6. 在线人数统计session管理

    下午比较闲(其实今天都很闲),想了一下在线人数统计方面的实现,上网找了下这方面的知识,最初我的想法是,管理session,如果session销毁了就减少,如果登陆用户了就新增一个,但是如果是用户非法退 ...

  7. [转]用HttpSessionListener与HttpSessionBindingListener实现在线人数统计

    原文链接:http://www.cnblogs.com/shencheng/archive/2011/01/07/1930227.html 下午比较闲(其实今天都很闲),想了一下在线人数统计方面的实现 ...

  8. ASP.NET MVC5+EF6+EasyUI 后台管理系统(39)-在线人数统计探讨

    系列目录 基于web的网站在线统计一直处于不是很精准的状态!基本上没有一种方法可以确实的统计在线用户! Discuz!NT 在线用户功能算是做得比较好的!参考资料 他的原理大致是根据用户的操作间隔来确 ...

  9. Java设计模式(一) 简单工厂模式不简单

    摘要:本文介绍了简单工厂模式的概念,优缺点,实现方式,以及结合Annotation和反射的改良方案(让简单工厂模式不简单).同时介绍了简单工厂模式(未)遵循的OOP原则.最后给出了简单工厂模式在JDB ...

  10. spring 第一篇(1-1):让java开发变得更简单(下)

    切面(aspects)应用 DI能够让你的软件组件间保持松耦合,而面向切面编程(AOP)能够让你捕获到在整个应用中可重用的组件功能.在软件系统中,AOP通常被定义为提升关注点分离的一个技术.系统由很多 ...

随机推荐

  1. ElasticSearch性能原理拆解

    逐层拆分ElasticSearch的概念 Cluster:集群,Es是一个可以横向扩展的检索引擎(部分时候当作存储数据库使用),一个Es集群由一个唯一的名字标识,默认为"elasticsea ...

  2. React jsx中js表达式

    嵌入JS表达式 在jsx语法中,要把JS代码写到{ }中,所有标签必须要闭合. let num = 100 let bool = false; // JSX 语法 var myh1 = ( <d ...

  3. 【二分答案】P2390 地标访问

    \(\color{black}\text{P2390 地标访问 (传送门)}\) 学过区间 DP 的,看到这题的第一反应都是:访问的地标一定是一个区间,并且在不断扩大,区间 DP!可看到数据范围,又瞬 ...

  4. vue双曲线

    原型 1 <template> 2 <div :class="className" :style="{height:height,width:width ...

  5. 写的程序总是出 BUG,只好请佛祖前来镇楼啦

    前言 自己之前写着玩的,在这做个备份,感觉不错的取走即可. 南无阿弥陀佛 佛祖镇楼,BUG 消失,永不怠机. ///////////////////////////////////////////// ...

  6. js沙雕排序之睡眠排序&随机排序

    1.睡眠排序,只要睡的时间多少就可以排序出来不要在乎时间多少 var arr=[4,77,741,41,142,52,244]; var sleepSort=function(arr,callback ...

  7. Mac 上切换 node 版本总结

    Mac 上切换 node 版本总结 背景 在做项目的时候,往往会遇到老项目没有升级的问题,node环境版本比较低,自己电脑安装或者新项目安装了最新版本的 node 环境,那么既要支持老版本的使用也要支 ...

  8. Prime Solutions

    Prime Solutions 以下是一段中学时代的惨痛回忆-每当学到排列组合的单元时,最痛苦的不是分析题目,也不是带错公式或计算错误,而是所谓的「苦工题」,以下这题是个例子:给定正整数N与S,求出方 ...

  9. vue cli4.0项目引入typescript

    现有的项目是采用vue cli4.0脚手架生成的,现在想要引入typescript. 1.执行安装命令 npm install --save-dev typescript npm install -- ...

  10. 第三方App与Termux命令建立IO通道

    目录 前言 一.Android 进程间通信(IPC) 二.Netcat 网络瑞士军刀 三.第三方 App 与 Termux 建立 TCP/Socket 通信 四.应用:调用 LSP 语言服务器 参见 ...