• ASP.net中网站访问量统计方法


    仅共学习

      一、建立一个数据表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为用户进入时间。

      四、创建定时器,定时操作有关数据

      对以上IPSta数据库的数据,需要创建一个或者几个定时器,

      并在每天晚上24时前的10秒钟内统计一天的流量,然后将其删除,把统计结果保存到另一个数据表中,供页面显示昨日访问量是调用。

  • 相关阅读:
    用js模拟struts2的多action调用
    24点经典算法
    操作系统的页面置换C++算法:OPT FIFO LRU CLOCK 计算缺页率
    java假设模拟请求重新启动路由器(网络爬虫经常使用),还有java怎样下载图片
    extern用法总结!
    sizeof,终极无惑(上)
    web 富文本编辑器总结
    ubuntu12.04 安装配置jdk1.7
    前端学习——使用Ajax方式POST JSON数据包
    AccountManager使用教程
  • 原文地址:https://www.cnblogs.com/UnJie/p/3940550.html
Copyright © 2020-2023  润新知