记录用户在网站上的逗留时间

原创 2002年06月13日 13:18:00
 

记录用户在网站上的逗留时间

我们总是对网站的流量很关心,但网站的流量多少并不能说明你的网页具有多少吸引力。能更准确地说明你的网站吸引力的,是用户在你的网站上逗留的时间。这篇文章中的思路就是想实现这个功能,而且它还可以让你知道当前有多少用户在线。

为了实现这个功能,首先一个网站要有“登陆框”。你需要一个数据库(记录用户和他们登陆与注销的时间),需要global.asa文件(这样你可以在当Session.Abandon发生或者Session.Timeout终止时使用Session_OnEnd事件追踪时间。这个时间是当用户击中“注销”或者退出你的程序时的时间)。

数据库

数据库采用MS Access 2000数据库(mdb文件)。它包含有两张表:Members表和User_LogTimes表。在Members表里保留一些登陆信息如:user name, Password, user first nameuser last name。在User_LogTime表中,保留了用户登陆/注销的时间的记录,而且从这个表里我们可以知道网站上有多少个用户在线。

数据库的设计这里略去。

脚本

login.asp

当一个用户在你的站点上登陆,login.asp中的脚本首先被执行。当用户在登陆框中输入用户名和密码,你需要创建一个查询来从Members表中得到用户ID。这个值将被存储在对话变量中:

 

'从登陆框中得到用户名和密码

UserName = Request.Form ("UserName")

Password = Request.Form ("Password")

...

...

set conn = Server.CreateObject ("ADODB.Connection")

conn.Open Application("connString")

query = "SELECT Id FROM Members WHERE UserName='" &_ UserName & "' AND Password='" & Password &_ "'"

' 从数据库中得到用户ID

set rs = conn.Execute (query)

...

...

'Members表里在对话变量中设置用户ID

Session("member") = rs("Id")

 

Session("member")变量中有了用户ID后,现在我们必须在User_LogTime表中对这个把Offline字段设置为False(意思是他已经在线)的用户的所有记录进行修改,而且还要把那个字段设置为True。这样改变的字段将不会有一个注销时间。一般这个操作不会影响表里的任何记录。“Offline”字段的记录设置为False也许会存在当用户没有适当地关闭或用户仓促地注销的情况。

然后我们在User_LogTime表里使用用户IDuser_id,用户的SessionID和用户的登陆时间(login time插入到一个新的记录:

 

' User_LogTime中对应修改这个用户的所有记录

query = "UPDATE User_LogTime SET offline=True WHERE offline=False AND user_id="&_ session("member")

conn.Execute (query)

'User_LogTime表中用user_idSessionID login time插入新的记录

query = "INSERT INTO User_LogTime (user_id, SID, Login_Time) "

query = query &_"VALUES (" & Session("member") & "," &_ Session.SessionID & ",#" & now() & "#)"

conn.Execute (query)

 

global.asa

当一个对话开始时上面的代码被呼叫,你得到登陆时间,然后将它们写进数据库。

当用户击中“注销”,然后Session.Abandon被呼叫。如果用户没有点击“注销”就退出程序,那么在session.Timeout终止时,Session_OnEnd就会被执行。在这个过程中你会更新已经写进login.asp的记录,然后更新Logout_time,修改offline字段为TRUE

 

Sub Session_OnEnd

set conn = Server.CreateObject ("ADODB.Connection")

conn.Open Application("connString")

'当用户注销时更新记录,记下注销时间,再设置用户为Offline

query = "UPDATE User_LogTime SET Logout_Time=#" & now() & "#, offline=True "

query = query & "WHERE offline=False AND SID=" & Session.SessionID &_ " AND user_id=" & Session("member")     

conn.Execute (query)

conn.Close

set conn = Nothing

End Sub

 

在线用户

有了Offline字段就使这个问题变的容易了。你可以产生一个SQL查询,像这样:

query = "SELECT DISTINCT user_id FROM User_LogTime WHERE offline=False"

执行查询,记录里的数字将是你的在线用户的数字。你可以有选择地呼叫:

query = "SELECT COUNT(*) as NumOnline FROM User_LogTime WHERE offline=False"

用一个记录返回一个记录,字段(“NumOnline”)就是在线用户的数量。

这样,我们就完成了这个实例的模型,剩下的就是一些细枝末节的工作了。我们可以将它的功能扩展。但是要注意Win95/98PWS 会工作的很好,但在IIS5上,记得Session_OnEnd会通过IWAM_machine运行,而不是通过IUSR。所以在有登陆/注销时间的数据库中一定要设置写/修改的权利。

记录用户在网站上的逗留时间

我们总是对网站的流量很关心,但网站的流量多少并不能说明你的网页具有多少吸引力。能更准确地说明你的网站吸引力的,是用户在你的网站上逗留的时间。这篇文章中的思路就是想实现这个功能,而且它还可以让你知道当前有多少用户在线。

为了实现这个功能,首先一个网站要有“登陆框”。你需要一个数据库(记录用户和他们登陆与注销的时间),需要global.asa文件(这样你可以在当Session.Abandon发生或者Session.Timeout终止时使用Session_OnEnd事件追踪时间。这个时间是当用户击中“注销”或者退出你的程序时的时间)。

数据库

数据库采用MS Access 2000数据库(mdb文件)。它包含有两张表:Members表和User_LogTimes表。在Members表里保留一些登陆信息如:user name, Password, user first nameuser last name。在User_LogTime表中,保留了用户登陆/注销的时间的记录,而且从这个表里我们可以知道网站上有多少个用户在线。

数据库的设计这里略去。详见下图的设计:

脚本

login.asp

当一个用户在你的站点上登陆,login.asp中的脚本首先被执行。当用户在登陆框中输入用户名和密码,你需要创建一个查询来从Members表中得到用户ID。这个值将被存储在对话变量中:

 

'从登陆框中得到用户名和密码

UserName = Request.Form ("UserName")

Password = Request.Form ("Password")

...

...

set conn = Server.CreateObject ("ADODB.Connection")

conn.Open Application("connString")

query = "SELECT Id FROM Members WHERE UserName='" &_ UserName & "' AND Password='" & Password &_ "'"

' 从数据库中得到用户ID

set rs = conn.Execute (query)

...

...

'Members表里在对话变量中设置用户ID

Session("member") = rs("Id")

 

Session("member")变量中有了用户ID后,现在我们必须在User_LogTime表中对这个把Offline字段设置为False(意思是他已经在线)的用户的所有记录进行修改,而且还要把那个字段设置为True。这样改变的字段将不会有一个注销时间。一般这个操作不会影响表里的任何记录。“Offline”字段的记录设置为False也许会存在当用户没有适当地关闭或用户仓促地注销的情况。

然后我们在User_LogTime表里使用用户IDuser_id,用户的SessionID和用户的登陆时间(login time插入到一个新的记录:

 

' User_LogTime中对应修改这个用户的所有记录

query = "UPDATE User_LogTime SET offline=True WHERE offline=False AND user_id="&_ session("member")

conn.Execute (query)

'User_LogTime表中用user_idSessionID login time插入新的记录

query = "INSERT INTO User_LogTime (user_id, SID, Login_Time) "

query = query &_"VALUES (" & Session("member") & "," &_ Session.SessionID & ",#" & now() & "#)"

conn.Execute (query)

 

global.asa

当一个对话开始时上面的代码被呼叫,你得到登陆时间,然后将它们写进数据库。

当用户击中“注销”,然后Session.Abandon被呼叫。如果用户没有点击“注销”就退出程序,那么在session.Timeout终止时,Session_OnEnd就会被执行。在这个过程中你会更新已经写进login.asp的记录,然后更新Logout_time,修改offline字段为TRUE

 

Sub Session_OnEnd

set conn = Server.CreateObject ("ADODB.Connection")

conn.Open Application("connString")

'当用户注销时更新记录,记下注销时间,再设置用户为Offline

query = "UPDATE User_LogTime SET Logout_Time=#" & now() & "#, offline=True "

query = query & "WHERE offline=False AND SID=" & Session.SessionID &_ " AND user_id=" & Session("member")     

conn.Execute (query)

conn.Close

set conn = Nothing

End Sub

 

在线用户

有了Offline字段就使这个问题变的容易了。你可以产生一个SQL查询,像这样:

query = "SELECT DISTINCT user_id FROM User_LogTime WHERE offline=False"

执行查询,记录里的数字将是你的在线用户的数字。你可以有选择地呼叫:

query = "SELECT COUNT(*) as NumOnline FROM User_LogTime WHERE offline=False"

用一个记录返回一个记录,字段(“NumOnline”)就是在线用户的数量。

这样,我们就完成了这个实例的模型,剩下的就是一些细枝末节的工作了。我们可以将它的功能扩展。但是要注意Win95/98PWS 会工作的很好,但在IIS5上,记得Session_OnEnd会通过IWAM_machine运行,而不是通过IUSR。所以在有登陆/注销时间的数据库中一定要设置写/修改的权利。

JS脚本操作COOKIE

// -------------------------// JavaScript的Cookies函数库// -------------------------// 保存Cookiefunction ...
  • vogts
  • vogts
  • 2005年09月11日 14:09
  • 1074

Servlet—Cookie(显示用户上次访问时间、显示商品浏览历史)

1 . 什么是会话? 会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话。 1.1 会话过程中要解决的一些问题? 每个用户在使用浏览...
  • Xw_Classmate
  • Xw_Classmate
  • 2016年02月25日 13:47
  • 1996

pageoffice在网站上部署

pageoffice在网站发布以后遇见的问题,在线打开文档时,报错:无法找到server.cs文件。网站发布后,该文件已经编译过,故拷贝该文件到网站根目录也是无用。 原因是,在网站bin目录里添加...
  • StevenTitan
  • StevenTitan
  • 2017年12月20日 12:10
  • 11

apache2部署访问yaaw

参考: http://jingyan.baidu.com/article/9158e0006581d1a2541228b5.html下载完成yaaw-master并放在/var/www/目录下后 ...
  • lovelovelovelovelo
  • lovelovelovelovelo
  • 2016年12月25日 22:54
  • 483

UIImageView图片动画

UIImageView使用   今天试试运用 UIImageView 来制作一个"营火动画" 首先运行以安装好的 xCode,和第一天一样 选择: File->New Project. 从...
  • Liar0606
  • Liar0606
  • 2013年09月25日 14:36
  • 1476

linux——centos下搭建java开发环境(使用yum+外网无法访问腾讯云的tomcat问题)

此内容是在centos下,使用yum完成的,如果是Ubuntu的版本,不能使用yum。关于yum是什么,可以自行百度。 第一步 安装java的sdk 解释一下 第一条命令,列出了在yum中的所有j...
  • qq_32846595
  • qq_32846595
  • 2017年07月03日 19:58
  • 262

在纯HTML的静态网页中添加一…

不错原文地址:在纯HTML的静态网页中添加一段统计网页访问量的代码作者:alias如何在纯HTML的静态网页中添加一段统计网页访问量的JAVA Script代码? 如何在网站上进行流量统计呢,可以找...
  • lyp0715
  • lyp0715
  • 2016年01月21日 10:21
  • 335

记录用户上次访问时间的代码实现

记录用户上次访问时间的代码实现 Cookie的简单的使用 获得从浏览器带过来的Cookie 通过HttpServletRequest对象中的方法: getCookies(); 获得浏览器带过来...
  • boss_way
  • boss_way
  • 2017年11月21日 12:37
  • 117

Python网络爬虫,在网站上扒数据

做科研的各位兄弟,有时候需要数据,但是无处获得,用Pyhton学会做网络爬虫之后,数据到处都是!!!...
  • qiangzaizaiO
  • qiangzaizaiO
  • 2016年10月06日 18:56
  • 2820

在网站上爬取实习岗位

package zhihu_scrapy; import java.io.*; import java.net.*; import java.util.regex.*; /*实现爬取只爬取的所有岗位中...
  • learninginJAVA
  • learninginJAVA
  • 2015年02月26日 14:40
  • 373
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:记录用户在网站上的逗留时间
举报原因:
原因补充:

(最多只允许输入30个字)