[转]用ASP编写网站流量统计系统

1、获得访问者ip

  dim m_ip

  m_ip=request.servervariables("remote_host")

  用上面的语句可以取得访问者的ip。

  2、获得浏览器信息

  dim o_browser,m_browsertype

  set o_browser=server.createobject("mswc.browsertype")

  m_browsertype=o_browser.browser+o_browser.version

  3、获得访问时间

  dim m_datetime

 m_datetime=year(date())&"/"&right("0"&month(date()),2)&"/"right("0"&day(date()),2)&"/"&right("0"&hour(time()),2)&":"&right("0"&minute(time()),2)&":"&right("0"&second(time()),2)  



  4、取得用户的操作系统。

  在asp中使用如下语句可以得到访问者的http_user_agent字符串。

  dim struseragent

  struseragent=request.servervariables("http_user_agent")

  这个字符串一般是如下格式:

  mozilla/4.0 (compatible; msie 4.01; windows 98)

  上面的字符串可以说明访问者使用的操作系统是windows98,浏览器是msie 4.01,但是这个字符串格式不固定,而且可以自己更改。

  平常我们所见的其它一些主要的useragent字符串如下:

  使用ie的浏览器:

  mozilla/2.0 (compatible; msie 3.01; windows 95)

  mozilla/4.0 (compatible; msie 4.0; windows 95);

  mozilla/4.0 (compatible; msie 4.01; windows 98)

  mozilla/4.0 (compatible; msie 5.0; windows 98);

  mozilla/4.0 (compatible; msie 5.0b2; windows nt)

  使用netscape的浏览器:

  mozilla/4.03 〔en〕 (win95; i)

  mozilla/4.08 〔en〕 (winnt; u ;nav)

  mozilla/4.5 〔en〕 (winnt; u)

  mozilla/3.04gold (win95; i)

  使用opera的浏览器:

  mozilla/4.0 (compatible; opera/3.0; windows 95) 3.50b10

  frontpage编辑器:

  mozilla/2.0 (compatible; ms frontpage 3.0)

  使用sun操作系统:

  mozilla/3.01gold (x11; i; sunos 5.7 i86pc)

  使用powerpc的mac机:

  mozilla/4.0 (compatible; msie 4.5; mac_powerpc)

  通过分析以上字符串,我们可以找出规律,编写一个子程序来判断访问者用的是何种操作系统,又由于用asp中的判断浏览器类型的控件需要更新browser.ini文件,所以我们可以结合这个字符串来判断浏览器属性。

  我们以什么样的方式来统计网站呢?

  我们可以让用户在他的主页上加入如下语句:

  <a href="http://www.abc.com/viewer.asp?userid=username"><img src="http://www.abc.com/counter.asp?userid=username"></a>上面的userid是具体哪一个用户,要注意用户和访问者不是一个概念。

  通过上面的字符串我们就可以采集用户的访问数据,并给用户提供观看数据的链接。在我们看加有网易的统计系统的页面时会发现它会返回给用户一个图标,我们就可以在counter.asp中实现这个功能。

  加入:response.redirect "http://www.abc.com/abc.gif"

  这个语句我们可以加在统计数据采集后返回给用户。

  如何设计数据表结构?

设计表结构是一项极其重要的工作,它的合理与否与程序的编制紧密相关。

  一个网站统计系统应该有一个用户表,统计值表。

  这个用户表也就是保留注册用户信息的表,统计值表就是记录用户的每一项统计指标值的表。在统计值的表中我们可以指定用户的统计指标,我们可把每一个指标用一个id值来表示,这里我们简单举例。

  用户表:

table name:regist_table

field type

username c 用户名

password c 密码

regdate c 注册时间

  值表:

table name:value_table

field type

username c 用户名

id c 统计指标id

value i

datetime c 统计指标的值

  id列表:

table name:id_table

field type

id c 统计指标id

idvalue c 统计指标的说明

 

  有了这三个表我们就可以开始做了。

  如我们可以指定以下id

id idvalue

101 总访问量

201 1日访问量

202 2日访问量

: :

: :

231 31日访问量

  要想对用户开始统计我们必须得先让用户注册,用户使用的流程如下:

  填注册表->初始用户的value表(把对应的id加入)->把注册信息反馈给用户->用户在自己的页面上加入链接->开始统计

  能采集数据我们都能采到了,那么我们就开始编制asp的统计页面。

  这一页我们叫计数页,counter.asp

  这段asp代码我们需要让它按如下的流程进行采集数据并保存数据和更新数据:

  采集用户名,判断用户名是否合法,采集访问者的信息,对信息进行加工,进行保存和更新数据库,返回logo图标。

  调用这个asp用counter.asp?user=abc这个方式。

  采集用户名我们可以用request对象的相应方法取得,然后检查用户表判断用户是否合法,然后取信息,用我们上面讲到的取得相应信息的方法取得信息,然后进行加工保存在数据表里,但最重要的是如何对数据进行更新,如当日每小时访问统计数,当天每小时统计数等,我们如何对每天的数据进行更新是这个程式的要点,我们可以采取几种方式,如对每天的每个小时的记录的更新我们采取在每天午夜12点更新,对每月的每一天的数据我们在月份切换的那一天进行更新。

  下面我讲一下具体的流程,以月份统计举例:

  1,得出上一次的统计的日期时间

  2,得出当前的日期时间,当前月份并转化成相应的id

  3,判断当前月份与上一次月份是否相同,如果相同则给总数加1,当前月的id累加1,如不相同则清零所有月份id,只给总数id加1

  4,根据月份统计我们可以做一下小时统计,周统计,天统计。

按如上的流程我们就可以做统计页了,要注意每个id的分配要分类明确代表的含义要明晰。

posted @ 2013-03-14 22:07  Roboo  阅读(283)  评论(0编辑  收藏  举报