配置文件的使用——在线用户统计

简介:
如果充分利用了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。这样,我们的程序就可以在不同的访问者环境中顺利运行。 
  
    如果充分利用web.config等配置文件,可以充分体现asp.net的优势和特性,可以将连接数据库的字符串写在配置文件中,这样,既实现了安全性,也更易于程序的维护。如:
<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"]; // 系统默认数据库连接串


本文转自 august 51CTO博客,原文链接:http://blog.51cto.com/august/6943,如需转载请自行联系原作者
相关文章
|
JSON 关系型数据库 大数据
电商项目之用户行为日志字段分析|学习笔记
快速学习电商项目之用户行为日志字段分析
250 0
|
网络协议 测试技术 Go
海量用户通讯系统-显示在线用户列表(5)|学习笔记
快速学习海量用户通讯系统-显示在线用户列表(5)
73 0
|
机器学习/深度学习 JSON 前端开发
海量用户通讯系统-显示在线用户列表(4)|学习笔记
快速学习海量用户通讯系统-显示在线用户列表(4)
78 0
|
机器学习/深度学习 JSON 网络协议
海量用户通讯系统-显示在线用户列表(7)|学习笔记
快速学习海量用户通讯系统-显示在线用户列表(7)
92 0
|
机器学习/深度学习 JSON 网络协议
海量用户通讯系统-显示在线用户列表(3)|学习笔记
快速学习海量用户通讯系统-显示在线用户列表(3)
98 0
|
JSON 网络协议 测试技术
海量用户通讯系统-显示在线用户列表(6)|学习笔记
快速学习海量用户通讯系统-显示在线用户列表(6)
88 0
|
网络协议 测试技术 Go
海量用户通讯系统-显示在线用户列表(1)|学习笔记
快速学习海量用户通讯系统-显示在线用户列表(1)
144 0
海量用户通讯系统-显示在线用户列表(1)|学习笔记
|
网络协议 测试技术 Go
海量用户通讯系统-显示在线用户列表(2)|学习笔记
快速学习海量用户通讯系统-显示在线用户列表(2)
59 0
|
Web App开发 弹性计算 监控
日志服务之分析用户访问行为-2
日志服务之分析用户访问行为-2
86 0