我们用Redis去在存线用户的信息,当用户登陆了,我们就就往Redis写这条用户信息。
同时用户每请求一次,我们就去更新在线用户的信息,更新该用户的最后在线的时间,同时删除过期用户的信息。
这样的话,还不能实时,为了能达到实时,
我们在页面上加了一个js的定时器。每过1s(这个时间可以酌情设置)
往服务器端发送一个请求。删除过期用户,拉取当前在线的用户信息。
在这个拉取过程中,有个问题,我们发送请求的时候是带cookie的,这样的话,在服务器端会更新session的状态。
也就是session永久不会过期,这样,我们之前设计的30分钟用户过期,重新跳转到登陆页面的,功能就受到影响。
那么我们就要解决,在这次拉去过程中,更新Session。
分析代码,看到了这次请求是走的api,同时在api中 启用了session。
那么只要,这个接口调用不走这个session,就ok了。
经分析修改代码:
public override void Init() { this.PostAuthenticateRequest += (sender, e) => { if (HttpContext.Current.Request.RawUrl.Contains("/api/SysManage/UserOnline/PostListUserByDepartment")) { return; } HttpContext.Current.SetSessionStateBehavior(System.Web.SessionState.SessionStateBehavior.Required); }; base.Init(); }
注意 :这个地方 Session保存的地方和在线用户信息保存的是分开,做在线用户清除的比较时间一定与Session的过期时间保持一致。
这样在线统计更准确。
时间: 2024-10-13 10:22:13