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

简介:
如果充分利用了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,如需转载请自行联系原作者
相关文章
|
3月前
用二维码收集信息时,在后台可以查看、统计哪些数据?
如果是用草料二维码平台搭建的二维码,前往后台,在表单列表中找到对应的表单,就能查看数据了,包括通过该表单收集到的所有明细数据、基于关联二维码的统计数据、填写该表单的填表人统计数据、基于表单组件的字段统计数据。
用二维码收集信息时,在后台可以查看、统计哪些数据?
|
7月前
|
弹性计算 运维 搜索推荐
|
JSON 前端开发 JavaScript
Echarts实战案例代码(15):月收入年龄分段等MYSQL分类统计PHP后台数据管理接口API数据的解决方案
Echarts实战案例代码(15):月收入年龄分段等MYSQL分类统计PHP后台数据管理接口API数据的解决方案
189 0
|
7月前
|
存储 移动开发 小程序
利用微搭搭建信息查询小程序
利用微搭搭建信息查询小程序
|
Web App开发 JavaScript PHP
记录VisualSVNServer配置在线密码修改功能
VisualSVN Server使用的是64位版 查看对应的apache版本号是 2.2.32.这个版本需要使用php5.5以下的,且需要使用64位的php。 下载php 5.4 的64位版本。 php的下载地址:官网地址:http://windows.php.net/download/ http://windows.php.net/downloads/pecl/releases/ 官网从5.5开始才提供了64位的bin包下载。
3186 0
|
JSON 关系型数据库 大数据
电商项目之用户行为日志字段分析|学习笔记
快速学习电商项目之用户行为日志字段分析
|
Oracle 关系型数据库
10G自动收集统计信息修改
10G自动收集统计信息修改
117 0
10G自动收集统计信息修改
|
Oracle 关系型数据库 Shell
[自制工具]批量后台更新统计信息
Oracle数据库有时需要批量收集数据库的统计信息,如在大量数据迁移或大量数据更新以后,但是收集的时间可能会较长,为了避免网络中断等意外情况可能引起的麻烦,今天调试了这个小脚本,可以分用户批量执行,同时记录执行时间等日志信息,比较实用。
219 0
|
测试技术
soufun使用次数统计,搜房网房源自动刷新程序 -- 测试版本,Dev.QQ 1205878060
soufun使用次数统计,搜房网房源自动刷新程序 -- 测试版本,Dev.QQ 1205878060  
905 0
下一篇
DataWorks