仅共学习

  一、建立一个数据表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秒钟内统计一天的流量,然后将其删除,把统计结果保存到另一个数据表中,供页面显示昨日访问量是调用。

ASP.net中网站访问量统计方法的更多相关文章

  1. ASP.net中网站访问量统计方法代码(在线人数,本月访问,本日访问,访问流量,累计访问)

    一.建立一个数据表IPStat用于存放用户信息 我在IPStat表中存放的用户信息只包括登录用户的IP(IP_Address),IP来源(IP_Src)和登录时间 (IP_DateTime),些表的信 ...

  2. 如何实现ASP.NET中网站访问量的统计

    如何实现ASP.NET中网站访问量的统计 2009-07-30 15:50 佚名 网翼教程网 字号:T | T 本文介绍了如何在asp.net中进行网站访问量的统计. AD:51CTO 网+ 第十二期 ...

  3. ASP.NET中在线用户统计

    统计在线用户的作用不言而喻,就是为了网站管理者可以知道当前用户的多少,然后根据用户数量来观察服务器或者程序的性能,从而可以直观的了解到网站的吸引力或者网站程序的效率.现在,我们就介绍一个简单明了的方法 ...

  4. Google Analytics SEO 实时 网站 访问量 统计

    /*************************************************************************** * Google Analytics SEO ...

  5. Servlet----------用servlet写一个“网站访问量统计“的小案例

    package cn.example; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.Ser ...

  6. hexo不蒜子网站访问量统计失效

    问题 hexo博客的不蒜子网站访问量统计最近失效了. 解决 原因 不蒜子域名更改了,所以需要修改博客的配置文件. 方法 进入博客目录下\themes\next\layout\_third-party\ ...

  7. 在 ASP.NET 中使用 jQuery.load() 方法

    今天就让我们看看在 ASP.NET 中使用 jQuery.load() 方法来调用 ASP.NET 的方法,实现无刷新的加载数据. 使用 jQuery 的朋友应该知道可以使用 jQuery.load( ...

  8. asp.net中导出Excel的方法

    一.asp.net中导出Excel的方法: 本文转载 在asp.net中导出Excel有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出 ...

  9. asp.net中导出Execl的方法

    一.asp.net中导出Execl的方法: 在 asp.net中导出Execl有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址 输出在浏览器上:一种是将文件直接将文件输出流写给 ...

随机推荐

  1. objective-c 错题

    //1, NSString *name = [[NSString alloc]initWithString:@"张三"]; NSLog(@"%d",[name ...

  2. iOS9 未受信任的企业级开发者

    升级iOS9,app打不开怎么办?6个步骤让你应对“未受信任的企业及开发者账号” 点开App,弹出未受信任的开发者,记住弹框中冒号后面的大写字母.关闭,进入设置. 进入通用 进入描述文件 找到所对应的 ...

  3. thinkphp3.2.2前后台公用类架构问题

    3.13之前好多项目都使用前后台公用类,在lib/action下创建Baseaction做为公共继承类,发现3.2.2里面很多人都用A调用,这样每用一次要用A调用,好麻烦,小编特意偷懒.亲测使用以下方 ...

  4. PHP框架、库和软件资源大全(整理篇)

    php的资料 https://github.com/ziadoz/awesome-php Awesome PHP A curated list of amazingly awesome PHP lib ...

  5. Oralce 字符串截取

    update E_SYS_STRATEGY set sconfigvalue=(select Substr((select sconfigvalue from E_SYS_STRATEGY where ...

  6. 【Java】Java6 WebService的发布

    WebService服务发布往往比较混乱,Axis2的发布形式与XFire发布方式差别很大,而Java6 Web服务的发布与Axis2.XFire的Web服务的发布方式也有着天壤之别,它们之间没有经验 ...

  7. Delphi调用WINAPI时到底应该是指针还是结构体(注意是Delphi变量本身就是指针)

    看MSDN,GetWindowRect的说明如下: BOOL WINAPI GetWindowRect( _In_  HWND   hWnd, _Out_ LPRECT lpRect // 注意,没* ...

  8. 使用next-key locks 用于搜索和索引扫描,可以防止幻读

    Next-Key Locks A next-key lock is a combination of a record lock on the index record and a gap lock ...

  9. 【转】Android4.3 蓝牙BLE初步

    原文网址:http://www.cnblogs.com/savagemorgan/p/3722657.html 一.关键概念: Generic Attribute Profile (GATT) 通过B ...

  10. [PHP] PHP Excel导出 以及编码问题

    PHP导出Excel 很简单 在一开头输入 下面就可以是Table,html或者PHP echo出来的都行 <? php header("Content-type:applicatio ...