被动式统计网站在线人数

在学校里不能上网时,没事做就改了下blog程序,加上了个blog在线人数统计。在此之前也看了几种统计在线人数的代码,感觉都不太符合自己的要求,就结合blog程序自己写了一个,应用到我的blog上。

在Fdream的blog里提到了一些关于ASP统计在线人数的方法,具体可以看这里。

为了兼顾准确率与效率,我采用了被动的方式来统计在线人,即当有新访客时才更新在线人数。不知道网上有没有已经有人使用了这种方法,不过我现在用的完全是自己想的^_^。

在L-Blog中采用Session来判断访客是否为新访客。Session的超时时间一般为20分钟,刚好可以用来统计在线人数,即20分钟内的活动访客认为是在线的。

在commond.asp有如下一段代码用来记录访问记录:
复制代码 代码如下:
' Guest_IP为访客的IP
IF Session("GuestIP")<>Guest_IP Then
    Dim Guest_Agent,Guest_Refer
    ' Guest_Agent和Guest_Refer访问记录要用到
    Guest_Agent=Trim(Request.ServerVariables("HTTP_USER_AGENT"))
    Guest_Refer=Trim(Request.ServerVariables("HTTP_REFERER"))
    ' 添加一个访问记录
    Conn.ExeCute("INSERT INTO blog_Counter(coun_IP,coun_Agent,coun_Refer) VALUES
    ('"&Guest_IP&"','"&Guest_Agent&"','"&Guest_Refer&"')")
    ' 访问次数加1
    Conn.ExeCute("UPDATE blog_Info SET blog_VisitNums=blog_VisitNums 1")
    SQLQueryNums=SQLQueryNums 2
    ' 用Session保存访客IP
    Session("GuestIP")=Guest_IP
End IF

为了实现在线人数统计,我在数据库里做了一些改动:

1. 在表blog_Info添加了1个字段blog_OnlineNums(整型),用来保存网站当前在线人数

2. 添加了表blog_Onine,字段设置为:ol_ID(自动编号),ol_IP(字符,20),ol_Time(日期/时间,默认值Now)。

修改后的站点统计代码如下:
复制代码 代码如下:
'站点统计代码
IF Session("GuestIP")<>Guest_IP Then
    ' 原来的站点访问计数器
    Conn.ExeCute("INSERT INTO blog_Counter(coun_IP,coun_Agent,coun_Refer)
    VALUES ('"&Guest_IP&"','"&Guest_Agent&"','"&Guest_Refer&"')")
    Conn.ExeCute("UPDATE blog_Info SET blog_VisitNums=blog_VisitNums+1")
    SQLQueryNums=SQLQueryNums+2
    Session("GuestIP")=Guest_IP
    '在线人数统计
    ' 判断在在线列表中是否在在已经超时的访客
    IF Conn.ExeCute("SELECT COUNT(ol_ID) FROM blog_Online
    WHERE DateDiff('n',ol_Time,Now())>20")(0)>0 Then
        ' 如果有则覆盖一个已超时访客的记录
        Conn.ExeCute("UPDATE blog_Online SET ol_IP='"&Guest_IP&"',
        ol_Time=Now() WHERE ol_ID IN (SELECT TOP 1 ol_ID
        FROM blog_Online WHERE DateDiff('n',ol_Time,Now())>20)")
    Else
        ' 如果没有则添加一条在线访客记录
        Conn.ExeCute("INSERT INTO blog_Online (ol_IP)
        VALUES ('"&Guest_IP&"')")
    End IF
    ' 统计blog在线人数
    blog_OnlineNums=Conn.ExeCute("SELECT DISTINCT COUNT(ol_ID)
    FROM blog_Online WHERE DateDiff('n',ol_Time,Now())<20")(0)
    ' 更新blog信息中的在线人数
    Conn.ExeCute("UPDATE blog_Info SET blog_OnlineNums="&blog_OnlineNums&"")
    SQLQueryNums=SQLQueryNums+3
End IF

这样,在blog中需要显示在线人数的地方引用变量blog_OnlineNums就行了。

并且因为是被动式统计,对blog页面执行时间的影响几乎可以忽略不计,另外,这个方法统计的blog在线人数也有一定的准确性,可以满足一般的需求了。

时间: 2024-10-29 13:36:17

被动式统计网站在线人数的相关文章

php实现统计网站在线人数的方法

  本文实例讲述了php实现统计网站在线人数的方法.分享给大家供大家参考.具体实现方法如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 <?php functi

php实现统计网站在线人数的方法_php技巧

本文实例讲述了php实现统计网站在线人数的方法.分享给大家供大家参考.具体实现方法如下: <?php function getIpAddress() { // 取得当前用户的IP地址 if (getenv('HTTP_CLIENT_IP')) { $ip = getenv('HTTP_CLIENT_IP'); } elseif (getenv('HTTP_X_FORWARDED_FOR')) { $ip = getenv('HTTP_X_FORWARDED_FOR'); } elseif (ge

java使用监听器实现一个统计网站在线人数的示例_java

本文主要介绍了java使用监听器实现一个统计网站在线人数的示例,具有一定的参考价值,有需要的朋友可以了解一下. (1)创建一个监听器实现类 要大致统计一个网站的在线人数,首先,可以通过ServletContextListener监听,当Web应用上下文启动时,在ServletContext中添加一个List,用来准备存放在线的用户名:然后,可以通过HttpSessionAttributeListener监听,当用户登录成功把用户名设置到Session中时同时将用户名存放到ServletConte

PHP+MYSQL实现统计网站在线人数

PHP+MYSQL实现网站在线人数,后台有MySQL数据库支持.可以直接统计出网站当前的在线人数. 首先是创建MYSQL数据库表.   CREATE TABLE tablename ( field type(max_length) DEFAULT 'default_value' (NOT) NULL }       可以使用的SQL语句. CREATE TABLE useronline ( timestamp int(15) DEFAULT '0' NOT NULL, ip varchar(40

asp.net Application统计网站在线人数详解

application对象读取数据的语法: '读 数据=application( "数据名称 ") '写 application( "数据名称 ")=数据 例: dim   i application(i)=application(i)+1 application数据非同步更新: application.lock   '锁定对象 application(i)=application(i)+1 application.unlock   '解除锁定 applicatio

ASP设计网站在线人数统计程序

程序|设计|统计|在线|在线人数 在浏览网页的时侯,常常可以看见一些"当前网站上的人数是XXX人"的在线人数同计.如何用ASP来做一个呢?首先,分析一下它的做法,一般来说,这些线上人数统计都是指一个时段内的访客人数统计.比如(5分钟内,10分钟内)而这个时间的长短,是由设计者设定的. 在这个时段内同计各个不同IP的访客总数,就可以得出当前的线上人数了,但这里有一个精确问题需要解决,至于用什么办法来精确地统计,那就是各人不同的做法了,比如可以用自动提交的页面,隔一段时间读取COOKIES

ASP实例:用ASP程序实现网站在线人数统计

程序|统计|在线|在线人数 在浏览网页的时侯,常常可以看见一些"当前网站上的人数是XXX人"的在线人数同计.如何用ASP来做一个呢?首先,分析一下它的做法,一般来说,这些线上人数统计都是指一个时段内的访客人数统计.比如(5分钟内,10分钟内)而这个时间的长短,是由设计者设定的. 在这个时段内同计各个不同IP的访客总数,就可以得出当前的线上人数了,但这里有一个精确问题需要解决,至于用什么办法来精确地统计,那就是各人不同的做法了,比如可以用自动提交的页面,隔一段时间读取COOKIES等等,

PHP+jquery实时显示网站在线人数的方法

 这篇文章主要介绍了PHP+jquery实时显示网站在线人数的方法,较为详细的分析了实时显示在线人数的原理与代码实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了PHP+jquery实时显示网站在线人数的方法.分享给大家供大家参考.具体分析如下: 在线人数最简单的就是直接利用js调用php,这样可以显示出有多少人访问了本站,如果要在用户未刷新页面的状态实时显示用户在线人数,我们可以利用jquery ajax来实现. 我们在一些应用中需要动态展示数据,比如当前在线人数,当

两种统计当前在线人数的方法

统计|在线|在线人数 第一种方法:利用AltaVista搜索引擎来实现 这种方法是检查与你的站点链接的数目.这里用AltaVista搜索引擎来实现.在这里,我们用如下搜索引擎: http://www.altavista.com/cgi-bin/query?kl=XX&pg=q&text=yes&q=link%3A&search=Search. 这是AltaVista的一个文本版本.这样可以节省我们大量的需要解析HTML的代码.接着,我们使用rawurlencode()来处理