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

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

你可能感兴趣的:(session,server,object,application,asp.net,sqlserver)