ASP.NET实现记录历史访问人数和当前在线人数

来源:互联网 发布:胡润百富 知乎 编辑:程序博客网 时间:2024/05/13 12:58

利用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();//当前在线人数
      
// 在此处放置用户代码以初始化页面
    }

<iframe align="middle" marginwidth="0" marginheight="0" src="http://l.thec.cn/lynnlin/googleContent728x90.htm" frameborder="0" width="650" scrolling="no" height="90"></iframe>

原创粉丝点击