在线用户列表案例(asp.net)

时间:2016-12-12 07:40:51
【文件属性】:

文件名称:在线用户列表案例(asp.net)

文件大小:48KB

文件格式:RAR

更新时间:2016-12-12 07:40:51

在线用户列表 在线用户统计 实时 源代码 案例

最近所做的一个项目需要用到的在线用户列表,上网搜索了一下发现现有的解决方案对用户意外退出的处理均不是太理想。一般来说,用户离开系统的方式有三种:主动注销、会话超时、直接关闭浏览器,对于前两种,我们很容易便可将该用户从在线列表中清除,关键是第三种(很多用户都是直接关闭窗口的~~郁闷ing),程序无法捕获窗口关闭的精确时间,只能等到会话超时后在能将该用户清除出在线列表,假设我们设置会话超时时间为60分钟,而用户登陆系统随便浏览一个页面就以关闭浏览器的方式退出的话,我们要在将近1小时后才能从在线列表中将该用户清除出去(想象一下,系统显示n多人在线,可能除了你之外其他的n-1人都关机走人了,汗一个先```),而本文将尝试寻找一个解决方案把这种尴尬降至最低。 我的大概思路是,给每在线用户增加一个RefreshTime属性,建立一个负责将当前用户的RefreshTime属性设置为当前时间的单独页面(Refresh.aspx),然后在系统的主要页面(也可以是所有页面)中通过xmlhttp不断地请求Refresh.aspx页面,一旦用户关闭了与本系统相关的所有窗口,即以直接关闭浏览器的方式退出系统,那么该用户的RefreshTime属性便不会自动更新了,我们再设置一个自动刷新的超时时间(这个要比会话超时短很多_refreshTimeout),当发现某用户超过_refreshTimeout的时间没有自动刷新,就能判定该用户已经以直接关闭浏览器的方式退出了。 假设我们设置会话超时时间为60分钟,自动刷新超时时间为1分钟,在客户端通过xmlhttp每隔25秒(之所以不设1分钟,是防止网速慢的时候访问Refresh.aspx超时,个人感觉,不一定正确)访问一次Refresh.aspx页面,在用户登陆、用户注销、检测用户是否在线的时候都执行清理超时用户(包括会话超时和自动刷新超时)操作,这样一来,在线用户列表的统计误差就由60分钟降至1分钟了。


【文件预览】:
ASP.NET在线用户列表精确版——解决用户意外退出在线列表无法及时更新问题 - 莫问奴归处 - 博客园.url
OnlineUser
----OnlineUser()
--------ActiveUser.cs(2KB)
--------Refresh.cs(1KB)
--------Properties()
--------Script.cs(3KB)
--------OnlineUser.csproj(2KB)
--------PassPort.cs(9KB)
--------obj()
--------bin()
----OnlineUser.sln(2KB)
----OnlineUser.suo(27KB)
----WebSite3()
--------web.config(6KB)
--------Default2.aspx.cs(2KB)
--------Default2.aspx(1KB)
--------Bin()
--------Default3.aspx.cs(428B)
--------Default4.aspx.cs(260B)
--------Global.asax(2KB)
--------Default4.aspx(432B)
--------Default.aspx.cs(3KB)
--------Default.aspx(1KB)
--------Default3.aspx(432B)

网友评论

  • 非常好用,谢谢大哥的分享
  • 有一定的参考价值。
  • 不错,这种方式还是很有价值,谢谢楼主!