这里的在线统计是靠 Session_Start(object sender, EventArgs e), Session_End(object sender, EventArgs e) 两个事件来完成的,这两个事件大家都知道是在Global.asax文件中的,当然也可以写在Global.cs中了。 每当一个用户上到你的网站都会触发一个Session_Start(object sender, EventArgs e)事件;生成一个sessionid,这个sessionid是唯一的,我们就要这个sessionid来表示一个用户。每当一个session结束都触发Session_End(object sender, EventArgs e)事件。 我的处理步骤是: 1.Session_Start(object sender, EventArgs e)事件触发,就往数据库里面写入一个数据,sessionid做主健。 2.Session_End(object sender, EventArgs e)事件触发,就从数据库中删除一个数据,删除对应的sessionid行数据。 第一步: protected void Session_Start(object sender, EventArgs e) { this.Session.Timeout = 20; Application.Lock(); Pinbor.OnLine.Session_Start_OnLine(Context.Session.SessionID); //上面的代码就是要将这个sessionid写入数据库中,当然这里用户可以自己扩充,将IP,UserID等等信息也写入数据库. //Pinbor.OnLine.Session_Start_OnLine函数用户的自己写 Application.UnLock(); } 第二步: protected void Session_End(object sender, EventArgs e) { Application.Lock(); Pinbor.OnLine.Session_End_OnLine(Session.SessionID); //从数据库中删除一个数据,删除对应的sessionid行数据 //Session.SessionID是要结束的session的SessionID //Pinbor.OnLine.Session_Start_OnLine函数用户的自己写 Application.UnLock(); }