在线统计与跟踪

来源:互联网 发布:oracle sql分页查询 编辑:程序博客网 时间:2024/04/29 16:34

在做用户在线统计和跟踪的时候,发现总是存在统计的误差,
此处查看旧版本,在线的人数总是大于实际在线人数,测试了几遍,发现原因在于,已经退出的Session并没有立即失效。Session的timeout设置的时间太长,关闭页面后sessionID没有删除,试验了好多次,终于找到关闭浏览器后就能使Session立即失效的方法。

这个版本,模拟的是用户登录后的在先跟踪,此处下载:
主要做了下面改动
1 在登录跳转时,将用现有的用户名传入Cache中,更新用户名
UserInfo uInfo=new UserInfo();
uInfo.SessionID=this.Session.SessionID;
if(HttpContext.Current.Cache[uInfo.CacheKey]!=null)
{    
((UserInfo) HttpContext.Current.Cache[uInfo.CacheKey]).UserName=TextBox1.Text.Trim();
}

2 在登录后,关闭页面时,调用客户端onunload="removeline()",执行下面函数:
<script language="javaScript">
function removeline(){      if(event.clientX<0&&event.clientY<0)
{
       document.write('<iframe width="100" height="100" src="removeSession.aspx"></iframe><OBJECT classid=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2 height=0  id=WebBrowser width=0></OBJECT>');      document.all.WebBrowser.ExecWB(45,1);
}
}
 
onunload事件判断在关闭时时执行removeSession.aspx中Page_Load事件。
然后在removeSession.aspx中Page_load,执行下面语句:
Session.RemoveAll();
Session.Abandon();     
if(HttpContext.Current.Cache[this.Session.SessionID]!=null)
{            HttpContext.Current.Cache.Remove(this.Session.SessionID);   
}

经过这番修改,手动删除了Cache中的SessionID,使得在线统计终于准确,吁了一口小气:)
 

原创粉丝点击