<p> 在目前的网站统计系统决大部分都是CGI的,但编写起来特别复杂,而ASP学起来简单,更有和数据库结合的优点,所以结合自己曾经做过的网站统计系统,和大家探讨一下ASP编写网站统计系统。 </p><p> 大家都看过网易的网站统计系统,它可以统计总访问量,每日平均访问量,当日访问量,最高访问量,最高访问日期,日流量分析,月流量分析,周流量分析,浏览器分析,等等。</p><p> 其实要做一个ASP的访问统计系统关键是系统表结构的设计。以及如何来采集用户的CGI变量,如何来显示用户的信息。也就是说系统的关键是两个ASP程序,统计程序和显示程序。</p><p> 首先我们先看看如何来采集用户的访问信息。</p><p> 我们编写访问统计需要知道用户的如下信息,访问者的IP(根据访问IP可以形成访问者IP列表),访问者的浏览器与操作系统(统计访问者的浏览器与操作系统及所有访问者浏览器与操作系统比例图),访问者的访问时间(进行日访问量分析,月访问量分析,周访问量分析),下面我们来看看用ASP的获得以上信息的语句:</p><p> 1、获得访问者IP</p><p> Dim M_IP</p><p> M_IP=Request.Servervariables("REMOTE_HOST")</p><p> 用上面的语句可以取得访问者的IP。</p><p> 2、获得浏览器信息</p><p> Dim O_Browser,M_BrowserType</p><p> Set O_Browser=Server.Createobject("MSWC.BrowserType")</p><p> M_BrowserType=O_Browser.Browser+O_Browser.Version</p><p> 3、获得访问时间</p><p> Dim M_DateTime</p><p> 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)</p>
<p> </p>
<p> 4、取得用户的操作系统。</p><p> 在ASP中使用如下语句可以得到访问者的http_user_agent字符串。</p><p> Dim StrUserAgent</p><p> StrUserAgent=Request.ServerVariables("HTTP_USER_AGENT")</p><p> 这个字符串一般是如下格式:</p><p> Mozilla/4.0 (compatible; MSIE 4.01; Windows 98)</p><p> 上面的字符串可以说明访问者使用的操作系统是Windows98,浏览器是MSIE 4.01,但是这个字符串格式不固定,而且可以自己更改。</p><p> 平常我们所见的其它一些主要的UserAgent字符串如下:</p><p> 使用IE的浏览器:</p><p> Mozilla/2.0 (compatible; MSIE 3.01; Windows 95)</p><p> Mozilla/4.0 (compatible; MSIE 4.0; Windows 95);</p><p> Mozilla/4.0 (compatible; MSIE 4.01; Windows 98)</p><p> Mozilla/4.0 (compatible; MSIE 5.0; Windows 98);</p><p> Mozilla/4.0 (compatible; MSIE 5.0b2; Windows NT)</p><p> 使用NetScape的浏览器:</p><p> Mozilla/4.03 〔en〕 (Win95; I)</p><p> Mozilla/4.08 〔en〕 (WinNT; U ;Nav)</p><p> Mozilla/4.5 〔en〕 (WinNT; U)</p><p> Mozilla/3.04Gold (Win95; I)</p><p> 使用Opera的浏览器:</p><p> Mozilla/4.0 (compatible; Opera/3.0; Windows 95) 3.50b10</p><p> FrontPage编辑器:</p><p> Mozilla/2.0 (compatible; MS FrontPage 3.0)</p><p> 使用Sun操作系统:</p><p> Mozilla/3.01Gold (X11; I; SunOS 5.7 i86pc)</p><p> 使用PowerPc的Mac机:</p><p> Mozilla/4.0 (compatible; MSIE 4.5; Mac_PowerPC)</p><p> 通过分析以上字符串,我们可以找出规律,编写一个子程序来判断访问者用的是何种操作系统,又由于用ASP中的判断浏览器类型的控件需要更新Browser.ini文件,所以我们可以结合这个字符串来判断浏览器属性。</p>
<p> </p>
<p> 我们以什么样的方式来统计网站呢?</p><p> 我们可以让用户在他的主页上加入如下语句:</p><p> <a href="http://www.abc.com/viewer.asp?userid=username"><img src="http://www.abc.com/counter.asp?userid=username"></a>上面的userid是具体哪一个用户,要注意用户和访问者不是一个概念。</p><p> 通过上面的字符串我们就可以采集用户的访问数据,并给用户提供观看数据的链接。在我们看加有网易的统计系统的页面时会发现它会返回给用户一个图标,我们就可以在counter.asp中实现这个功能。</p><p> 加入:response.redirect "http://www.abc.com/abc.gif"</p><p> 这个语句我们可以加在统计数据采集后返回给用户。</p><p> 如何设计数据表结构?</p><p> 设计表结构是一项极其重要的工作,它的合理与否与程序的编制紧密相关。</p><p> 一个网站统计系统应该有一个用户表,统计值表。</p><p> 这个用户表也就是保留注册用户信息的表,统计值表就是记录用户的每一项统计指标值的表。在统计值的表中我们可以指定用户的统计指标,我们可把每一个指标用一个ID值来表示,这里我们简单举例。</p><p> 用户表:</p><p> Table Name:regist_table</p><p> Field type</p><p> username C 用户名</p><p> password C 密码</p><p> regdate C 注册时间</p><p> 值表:</p><p> Table Name:value_table</p><p> Field type</p><p> username c 用户名</p><p> id c 统计指标ID</p><p> value i</p><p> datetime c 统计指标的值</p><p> Id列表:</p><p> Table Name:id_table</p><p> Field type</p><p> id C 统计指标ID</p><p> idvalue C 统计指标的说明</p><p> 有了这三个表我们就可以开始做了。</p><p> 如我们可以指定以下ID</p><p> id idvalue</p>
<p> </p>
<p> 101 总访问量</p><p> 201 1日访问量</p><p> 202 2日访问量</p><p> : :</p><p> : :</p><p> 231 31日访问量</p><p> 要想对用户开始统计我们必须得先让用户注册,用户使用的流程如下:</p><p> 填注册表->初始用户的value表(把对应的ID加入)->把注册信息反馈给用户->用户在自己的页面上加入链接->开始统计</p><p> 能采集数据我们都能采到了,那么我们就开始编制ASP的统计页面。</p><p> 这一页我们叫计数页,counter.asp</p><p> 这段asp代码我们需要让它按如下的流程进行采集数据并保存数据和更新数据:</p><p> 采集用户名,判断用户名是否合法,采集访问者的信息,对信息进行加工,进行保存和更新数据库,返回logo图标。</p><p> 调用这个ASP用counter.asp?user=abc这个方式。</p><p> 采集用户名我们可以用Request对象的相应方法取得,然后检查用户表判断用户是否合法,然后取信息,用我们上面讲到的取得相应信息的方法取得信息,然后进行加工保存在数据表里,但最重要的是如何对数据进行更新,如当日每小时访问统计数,当天每小时统计数等,我们如何对每天的数据进行更新是这个程式的要点,我们可以采取几种方式,如对每天的每个小时的记录的更新我们采取在每天午夜12点更新,对每月的每一天的数据我们在月份切换的那一天进行更新。</p><p> 下面我讲一下具体的流程,以月份统计举例:</p><p> 1,得出上一次的统计的日期时间</p><p> 2,得出当前的日期时间,当前月份并转化成相应的ID</p><p> 3,判断当前月份与上一次月份是否相同,如果相同则给总数加1,当前月的ID累加1,如不相同则清零所有月份ID,只给总数ID加1</p><p> 4,根据月份统计我们可以做一下小时统计,周统计,天统计。</p><p> 按如上的流程我们就可以做统计页了,要注意每个ID的分配要分类明确代表的含义要明晰。</p>