利用Application对象和Session对象可以统计历史访问人数和当前在线人数。
1)在会话开始和结束时,一定要进行加锁和解锁操作。由于多个用户可以共享Application对象,因此加锁是必要的,这样可以保证在同一时刻只有一个客户可以修改和存取Application对象的属性。如果加锁后,迟迟不给开锁,会导致用户无法访问Application对象。我们可以使用对象的Unlock方法来解除锁定。
(2)我们是根据用户建立和退出会话来实现在线人数的增加、减少的,如果用户没有关闭浏览器,而直接进入其他URL,则这个会话在一定时间内是不会结束的,所以对在线用户的统计存在一定的偏差。当然我们可以在Web.config文件中对会话Session的失效时间Timeout来设置,默认值为20分钟,最小值为1分钟。
(3)只有在Web.config文件中的sessionstate模式设置为InProc时,才会引发Session_End事件。如果会话模式为StateServer或SQLServer,则不会引发该事件。
我们在网站中添加一个Global.asax全局应用程序文件.
在Global.asax如下:在Asp.net文件中如下:
protected void Application_Start(Object sender, EventArgs e)//当前应用程序启动这件事会发生
{
SqlConnection con=new SqlConnection("server=.;database=countPeople;uid=sa;pwd=;");
con.Open();
SqlCommand cmd=new SqlCommand("select * from countPeople",con);
int count=Convert.ToInt32(cmd.ExecuteScalar());
con.Close();
Application["total"]=count;//Application是个全局变量,每个会话都可对他操作
Application["online"]=0;
}
protected void Session_Start(Object sender, EventArgs e)//客户端一连接到服务器上,这个事件就会发生
{
Session.Timeout=1;
Application.Lock();//锁定后,只有这个Session能够会话
Application["total"]=(int)Application["total"]+1;
Application["online"]=(int)Application["online"]+1;
Application.UnLock();//会话完毕后解锁
}
protected void Session_End(Object sender, EventArgs e)//当会话结束时这个事件发生
{
Application.Lock();
Application["online"]=(int)Application["online"]-1;
Application.UnLock();
}
protected void Application_End(Object sender, EventArgs e))//当前应用程序启动这件事会发生
{
SqlConnection con=new SqlConnection("server=.;database=countPeople;uid=sa;pwd=;");
con.Open();
SqlCommand cmd=new SqlCommand("updata countPeople set num="+Application["total"],con);
cmd.ExecuteNonQuery();
con.Close();
}
private void Page_Load(object sender, System.EventArgs e)
{
this.lblTotal.Text=Application["total"].ToString();//历史访问人数
this.lblOnline.Text=Application["online"].ToString();//当前在线人数
// 在此处放置用户代码以初始化页面
}