本文统计用户登录时长的方法分为以下几步
1.设计用户登录日志表,里面主要的字段包含用户登录时间、用户登出时间、shiro创建的sessionId
2.登录时插入登录日志记录登录时间
3.登出时修改日志表记录登出时间(登出情况分为三种,用户点击系统提供的登出按钮、session过期以及用户直接关闭浏览器)
4.编写sql查询登录时长
补充:数据库表里之所以存储sessionId,一是因为这块没有做单点登录,同一用户可以在不同浏览器同时登录,故需要标志唯一一次会话以便修改数据库表记录。
思路有了接下来就是实现了,实现的难点主要在于监听关闭浏览器事件,前端核心代码如下:
var _beforeUnload_time=0;
var _gap_time=0;
window.addEventListener('beforeunload', e => this.beforeunloadHandler(e))
window.addEventListener('unload', e => this.unloadHandler(e))
function beforeunloadHandler(e){
this._beforeUnload_time=new Date().getTime();
}
function unloadHandler(e){
this._gap_time=new Date().getTime()-this._beforeUnload_time;
//判断是窗口关闭还是刷新
if(this._gap_time<=5){
//如果是登录状态,关闭窗口前,调用登出接口
//此处为调用登出接口的代码
}
}
这个问题解决了,剩下的代码逻辑想必大家也会写了,冲冲冲!