![]() |
|
用ASP统计用户在站点的停留时间
|
||||||||||||||||||||||||||||||||||||||||||||||||||||
广告招租,e-mail:yesize@hotmail.com
有两种很好的方法用来记录用户在你的站点上花费了多少时间。第一个是使用基于ASP服务器的sessions,第二是通过保持客户机端cookies。要记住,使用sessions将给服务器的处理工作增加负荷,但是它们确实提供了最简洁的方法。还有一点要注意,那就是如果用户端的浏览器不能支持cookie功能,那么这两种方法都不能工作。 ASP Session 技术 < script language=VBScript runat=server > Sub Session_onStart() save the time that the session started Session(StartTime) = Now() End Sub Sub Session_onEnd() get the time that the user last loaded a page assumes the default session timeout of 20 minutes On Error Resume Next set path and name of log file to be created edit to suit your own machine directory layout remember to give the directory Write or Full Control permission for the IUSR_machine account strFileName = C:Tempvisit_lengths.txt datStartTime = Session(StartTime) datEndTime = DateAdd(n, -20 , Now()) intMinutes = DateDiff(n, datStartTime, datEndTime) If intMinutes > 0 Then got a valid time so add it to the log file strInfo = Visit ending at & datEndTime _ & lasted for & intMinutes & minute(s). add user name to the log entry string here if required strInfo = strInfo & User name: & strUserName Set objFileObject = Server.CreateObject(Scripting.FileSystemObject) open text file to append data (the ForAppending constant = 8) Set objFile = objFileObject.OpenTextFile(strFileName, 8, True) objFile.WriteLine strInfo objFile.Close End If End Sub < /script > 你可以看到,当session 结束时,我们从当前时间中减去了session 的timeout的数值,如果考虑到用户装载最后一页时所花费的时间,减去的值可以稍微小一点。这个数量由你去猜,因为用这个技术并不能测出实际值。 注意,如果你在任何页面中使用了ASP的 Session.Abandon 方法,就不能得到正确的结果。因为这种方法立即中断session,这样,从实际时间中减去session长度就会给出一个不正确的访问时间(有时候甚至是负数)。更糟糕的是,在ASP 2.0版本中,这种方法还经常彻底不能启动Session_OnEnd事件。 在某些站点上使用一种中止服务器操作的链接来启动Session.Abandon方法,但是根据经验,很少有用户会去点击它。他们只是转到另一个站点,让session自行中断。 这是我们从日志文件中得到的一些记录: Visit ending at 6/5/00 1:05:26 AM lasted for 2 minute (s). Visit ending at 6/5/00 1:06:14 AM lasted for 47 minute(s). Visit ending at 6/5/00 1:12:18 AM lasted for 22 minute(s). Visit ending at 6/5/00 1:29:54 AM lasted for 9 minute(s). 如果用户访问的时间少于1分钟(比如说,他们的session开始后过了1分钟还没能装载另一页),用我们的代码就不显示在列表中。从整个session长度中减去这个session的timeout ,就会得到0,在这一点我们的代码就将其舍弃: If intMinutes > 0 Then ? 当然你可以修改代码以适应自己的需要。 注意:要记住session结束后才开始写日志文件的条目。你不能立刻看到它们。如果想试着更快地看到结果,可以在页面上修改Session.Timeout 的属性。
在数据库中记录结果 ... strSQL = INSERT INTO YourTable (UserName, SessionEnd, _ & SessionLength) VALUES ( & strUserName & , # _ & datEndTime & #, & intMinutes & ) Set oConn = Server.CreateObject(ADODB.Connection) oConn.open DSN=yourdsn;UID=username;PWD=password; oConn.Execute strSQL Set oConn = Nothing ... 然后你就可以用任何方式来使用这些数据了。你可以创建ASP页面来读取数据并将数据呈现给管理员,或者从数据库中将其复制到一个电子工作表中,有时间的时候再进行分析。 但是要记住,使用ASP sessions会带来一些问题。在ASP 2.0中,当主应用程序目录下的嵌套目录中有global.asa 的副本时,有时sessions 会丢失。还有,如果你在URL、页面文件名以及页面之间的超级链接中使用字母的大小写不同的话,象Navigator那样的浏览器就把URL作为大小写敏感来对待,因此不把特殊的ASP session cookie发送回来,这样这种方法的使用也是不可靠的。
客户机端Cookie技术 设置了路径和日志文件名之后,代码定义一个子程序,将一个值附加到日志文件的,就象前面的ASP Sessions的例子一样。如果你愿意的话,可以取代我们使用的代码来更新一个数据库表而不是一个日志文件。 < % measure visit length with cookie ? set path and name of log file to be created edit to suit your own machine directory layout remember to give the directory Write or Full Control permission for the IUSR_machine account strFileName = C:Tempvisit_lengths.txt Sub UpdateLogFile(intVisitLength) On Error Resume Next If intVisitLength > 0 Then got a valid time so enter it into a log file strInfo = Session ending at & Now() _ & lasted for & CStr(intVisitLength) & minute(s). add user name to the log entry string here if required strInfo = strInfo & User name: & strUserName Set objFileObject = Server.CreateObject(Scripting.FileSystemObject) open text file to append data (the ForAppending constant = 8) Set objFile = objFileObject.OpenTextFile(strFileName, 8, True) objFile.WriteLine strInfo objFile.Close Set objFile = Nothing Set objFileObject = Nothing End If End Sub 读一个存在的Cookie ... get session start time from existing cookie if it exists datStart = CDate(Request.Cookies(SiteVisits)(StartTime)) If Year(datStart) > 1990 Then cookie already exists, so get values datLast = CDate(Request.Cookies(SiteVisits)(LastTime)) If (DateDiff(n, datLast, Now()) > 30) Then more than 30 minutes since last visit so count as new visit get length of last visit and update log file intMinutes = DateDiff(n, datStart, datLast) UpdateLogFile intMinutes ... 这时,通过在页面的顶端执行UpdateLogFile子程序,我们已经存储了他们上一次访问的长度, 这是他们上次访问的分钟数。然后就可以把我们收集的两个值更新成当前的日期和时间,可以开始记录这次访问的长度了。 要注意,30分钟过去之后才能看到表格中的任何条目。在试验时,你可以用一个较短的值来修改代码。 记录访问的时间长度 update values for cookie use new start time and new last page load time datStart = Now() datLast = Now() Else ... 如果自从最后一次执行这个代码的时间少于30分钟,我们把它算成是当前访问的一部分,因此我们只需要更新cookie中的值作为他们上次访问的时间: ... less than 30 minutes since last visit so count as the same visit update values for cookie - just change the last page load time datLast = Now() End If Else ... 设置默认值 ... valid cookie does not exist so set values for a new one datStart = Now() datLast = Now() End If ... 创建返回Cookie值 ... create cookie to send back to client have to recreate whole cookie - cant just change some values Response.Cookies(SiteVisits)(StartTime) = datStart Response.Cookies(SiteVisits)(LastTime) = datLast Response.Cookies(SiteVisits).path = / apply to entire site make it stay on the users system for three months Response.Cookies(SiteVisits).expires = DateAdd(m, 3, Now) % > cookie技术的一个问题是当访问者重新回到你的站点时,你只能测量他上次访问的长度。为此,我们允许cookie在他们的机器上存在3个月,你可以修改这个时间值来适应你的需求。
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||