热烈祝贺台州朗动科技的站长论坛隆重上线!(2012-05-28)    热烈庆祝伟大的祖国60周年生日 点击进来我们一起为她祝福吧(2009-09-26)    站长论坛禁止发布广告,一经发现立即删除。谢谢各位合作!.(2009-08-08)    热烈祝贺台州网址导航全面升级,全新版本上线!希望各位一如既往地支持台州网址导航的发展.(2009-03-28)    台州站长论坛恭祝各位新年快乐,牛年行大运!(2009-01-24)    台州Link正式更名为台州网址导航,专业做以台州网址为主的网址导航!(2008-05-23)    热烈祝贺台州Link资讯改名为中国站长资讯!希望在以后日子里得到大家的大力支持和帮助!(2008-04-10)    热烈祝贺台州Link论坛改名为台州站长论坛!希望大家继续支持和鼓励!(2008-04-10)    台州站长论坛原[社会琐碎]版块更名为[生活百科]版块!(2007-09-05)    特此通知:新台州站长论坛的数据信息全部升级成功!">特此通知:新台州站长论坛的数据信息全部升级成功!(2007-09-01)    台州站长论坛对未通过验证的会员进行合理的清除,请您谅解(2007-08-30)    台州网址导航|上网导航诚邀世界各地的网站友情链接和友谊联盟,共同引领网站导航、前进!(2007-08-30)    禁止发广告之类的帖,已发现立即删除!(2007-08-30)    希望各位上传与下载有用资源和最新信息(2007-08-30)    热烈祝贺台州站长论坛全面升级成功,全新上线!(2007-08-30)    
便民网址导航,轻松网上冲浪。
台州维博网络专业开发网站门户平台系统
您当前的位置: 首页 » ASP/ASP.NET编程 » ASP.Net基础:在ASP.net中网站访问量统计方法

ASP.Net基础:在ASP.net中网站访问量统计方法

论坛链接
  • ASP.Net基础:在ASP.net中网站访问量统计方法
  • 发布时间:2009-05-29 22:01:50    浏览数:7612    发布者:jinlj    设置字体【   
一位QQ好友问我个人网站访问量是如何统计的,由于本人初学做网站,水平有限,所介绍的方法可能是笨方法,但在我网站上能够凑合着使用,希望大家多多指教。

一、建立一个数据表IPStat用于存放用户信息

我在IPStat表中存放的用户信息只包括登录用户的IP(IP_Address),IP来源(IP_Src)和登录时间(IP_DateTime),些表的信息本人只保存一天的信息,如果要统计每个月的信息则要保存一个月。因为我不太懂对数据日志的操作,所以创建此表,所以说我笨吧,哈哈。

二、在Global.asax中获取用户信息

在Global.asax的Session_Start即新会话启用时获取有关的信息,同时在这里实现在线人数、访问总人数的增量统计,代码如下:

void Session_Start(object sender, EventArgs e)

{

//获取访问者的IP

string ipAddress = Request.ServerVariables["REMOTE_ADDR"];

//获取访问者的来源

string ipSrc;

//判断是否从搜索引擎导航过来的

if (Request.UrlReferrer == null)

{

ipSrc = "";

}

else

{

//获取来源地址

ipSrc = Request.UrlReferrer.ToString();

}

//获取访问时间

DateTime ipDatetime = DateTime.Now;

//保存IP信息到数据库中

IPControl cont = new IPControl();

cont.AddIP(ipAddress, ipSrc, ipDatetime);


//获取用户访问的页面

string pageurl = Request.Url.ToString();

//判断访问的是否是默认页

if (pageurl.EndsWith("IPStat.aspx"))

{

//锁定变量

Application.Lock();

//为页面访问量+1

Application["StatCount"] = int.Parse(Application["StatCount"].ToString()) + 1;

//解锁

Application.UnLock();

}


//锁定变量

Session.Timeout = 10; //设定超时为10分钟

Application.Lock();

Application["countSession"] = Convert.ToInt32(Application["countSession"]) + 1;  //访问总人数+1

Application["onlineWhx"] = (int)Application["onlineWhx"] + 1; //在线人数加+1

Session["login_name"] = null;

//解锁

Application.UnLock();

}


提醒一句,别忘了下面的代码,以实现在用户离线时,将在线人数减去1.


void Session_End(object sender, EventArgs e)

{

// 在会话结束时运行的代码。

// 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为 InProc 时,才会引发 Session_End 事件。
      如果会话模式设置为 StateServer

// 或 SQLServer,则不会引发该事件。

//锁定变量

Application.Lock();

Application["onlineWhx"] = (int)Application["onlineWhx"] - 1; //在线人数减-1

Session["login_name"] = null;

//解锁

Application.UnLock();

}

三、将以上有关信息保存到数据库IPStat

创建了一个获取IP数据信息的类IPControl(),用来实现对数据库IPStat数据的操作,关于IPControl()类的内容,因为它是C#中对数据库的操作,以解Sql server 数据库,就能看懂它,这里就不作介绍了,请点击该链接查看。

为了实现将用户IP信息存入数据库,在上面代码中对IPControl()进行调用

//保存IP信息到数据库中

IPControl cont = new IPControl();

cont.AddIP(ipAddress, ipSrc, ipDatetime);

参数ipAddress为用户IP,ipSrc为用户来源, ipDatetime为用户进入时间。 chinaitlab
娱乐休闲专区A 影视预告B 音乐咖啡C 英语阶梯D 生活百科
网页编程专区E AMPZF HTMLG CSSH JSI ASPJ PHPK JSPL MySQLM AJAX
Linux技术区 N 系统管理O 服务器架设P 网络/硬件Q 编程序开发R 内核/嵌入
管理中心专区S 发布网址T 版主议事U 事务处理