如果充分利用了ASP.NET的特点,结合配置文件,如global.asax、web.config等,结合使用Application和Session,可以实现很多看似复杂,实际非常容易实现的问题。下面简单介绍使用application和global.asax实现的一个简单的在线用户统计。

一、用户显示页面的使用 

<%@ Page Language="c#" debug="true" %> 
<html> 
<head> 
<SCRIPT LANGUAGE="c#" RUNAT="server"> 
private void Page_Load(object sender, System.EventArgs e) 
{ 
Visitors.Text = "本站当前有: <b>" + Application["user_sessions"].ToString() + "" + "</b> 位访问者 !"; 
} 
<title>在线用户</title> 
</head> 
<body> 
<asp:label id="visitors" runat="server" /><br> 
</body> 
</html>


二、global.asax文件实现 
 

<script language="c#" runat="Server"> 
protected void Application_Start(Object sender, EventArgs e) 
{ 
Application["user_sessions"] = 0; 
} 
protected void Session_Start(Object sender, EventArgs e) 
{ 
Application.Lock(); 
Application["user_sessions"] = (int)Application["user_sessions"] + 1; 
Application.Unlock(); 
} 
protected void Session_End(Object sender, EventArgs e) 
{ 
Application.Lock(); 
Application["user_sessions"] = (int)Application["user_sessions"] - 1; 
Application.Unlock(); 
} 
</script>


 
  以上代码很容易理解,当网站开始服务的时候(Application开始的时候),程序设置Application["user_sessions"]为零,然后,当用户进入网站(Session开始的时候)的时候,锁定Application,然后,将application("user_sessions")加一,用户退出网站的时候,application("user_sessions")减一。这样,就很巧妙的实现了在线用户的统计。 
 
三、一点讨论
 
  以上的统计,简明扼要,程序很容易实现。但是,如果我们仔细考虑,发现该方法有一定的局限,统计出来的在线用户数量可能稍微有点误差。因为我们在以上程序中,是根据用户建立和退出会话(Session)来实现在线人数的加减的,而我们知道,如果用户没有关闭浏览器,而进入另外一个网站,那么,这个会话在一定的时间内是不会结束的,这个时间我们可以通过TimeOut来设置,一般的,我们设置为20分钟。所以,在用户数量统计上面,还是存在一点误差的。
 
  另外,我们知道,在ASP中,如果用户将浏览器上面的Cookies设置为“禁用”,那么,Session就不能再被传递,显然,这样设置让以上的统计程序无能为力。不过,在ASP.NET中我们有解决方法,在config.web文件中,我们将<sessionstate cookieless="false" />设置为true就可以了,也就说,不使用Cookies也可以传递Session。这样,我们的程序就可以在不同的访问者环境中顺利运行。 
  



<configuration>
    <appSettings>
  <add key="conn_Default" value="workstation id=server name;packet size=4096;data source=server name;initial catalog=database name;persist security info=True;user id=sa;pwd = ;"></add>
 </appSettings> 
 
 other settings here
 
 
</configuration>



那么就可以在连接数据库时使用如下的代码:



// ===数据库连接串设置===
  public static readonly string conn_Default = ConfigurationSettings.AppSettings["conn_Default"]; // 系统默认数据库连接串