不错呦!smile@林凯西,确保“准备文件”中的几个文件都有安装,S...您好,看了您这篇帖子觉得很有帮助。但是有个问题想请...我的修改过了怎么还被恶意注册呢 @jjjjiiii 用PJ快9年了,主要是A...PJ3啊,貌似很少有人用PJ了,现在不是WP就是z...@332347365,我当时接入时错误码没有-10...楼主,ChkValue值应为-103是什么意思呢?...大哥 你最近能看到我发的信息,请跟我联系,我有个制...
统计在线人数两种方案
编辑:dnawo 日期:2007-01-31
一、利用Session和Application对象的OnStart、OnEnd事件
这种方法是比较常见的,许多ASP书籍在介绍怎么统计在线人数时都是用这种方法。这种方法还得结合Global.asa,因为Session和Application对象的OnStart、OnEnd事件必须写在这里运行,典型的Global.asa内容如下:
<Script language="VBScript" runat="server">
sub application_onstart
application.lock
application("online")=0
application.unlock
end Sub
sub session_onstart
application.lock
application("online") = application("online") + 1
application.unlock
end sub
sub session_onend
application.lock
application("online")=application("online")-1
application.unlock
end sub
</Script>
弊端:用户不是正常退出登录(调用Session.Abandon方法退出登录),如直接关闭浏览器、地址栏输入网址直接转到其他网站时Session的OnEnd事件不会马上被触发,需等Session存活时间到才会触发OnEnd事件。
二、Session+数据库
源码如下:
弊端:在线人数多时对数据库访问过于频繁,占用服务器资源;每个页面中都需调用,使用没有第一种方法方便;从某种意义上说,这种方法应称为统计活动用户更为合适,因为用户在设定的时间内如果没有任何操作将被视为不在线。
这种方法是比较常见的,许多ASP书籍在介绍怎么统计在线人数时都是用这种方法。这种方法还得结合Global.asa,因为Session和Application对象的OnStart、OnEnd事件必须写在这里运行,典型的Global.asa内容如下:
复制内容到剪贴板
程序代码

<Script language="VBScript" runat="server">
sub application_onstart
application.lock
application("online")=0
application.unlock
end Sub
sub session_onstart
application.lock
application("online") = application("online") + 1
application.unlock
end sub
sub session_onend
application.lock
application("online")=application("online")-1
application.unlock
end sub
</Script>
弊端:用户不是正常退出登录(调用Session.Abandon方法退出登录),如直接关闭浏览器、地址栏输入网址直接转到其他网站时Session的OnEnd事件不会马上被触发,需等Session存活时间到才会触发OnEnd事件。
二、Session+数据库
源码如下:
复制内容到剪贴板
程序代码

<%
conn.execute("delete from online where datediff('s',datetime,now())>60") '删除60秒没有活动的访客,时间可以自己调整
Set rs=Server.CreateObject("ADODB.Recordset")
If session("username")="" then 判断用户未登录
sql="select * from online where id='"&session.sessionid&"'" '判断这个sessionid是否存在于数据库表中
rs.Open sql,Conn,1,3
If rs.eof then '访客第一次浏览
rs.addnew
rs("id")=session.sessionID
rs("name")="游客"
rs("online")=0 '0表示用户未登陆,是游客身份
rs("datetime")=now()
userip = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
If userip = "" Then
userip= Request.ServerVariables("REMOTE_ADDR")
End if
rs("ip")=userip
Else '访客非第一次浏览
rs("datetime")=now() '更新活动时间
rs.update
rs.close
End if
Else
sql="select * from online where id='" & session.sessionID & "' or admin='"&session("username")&"'" '判断sessionid 或者 用户名记录已存在数据表中
rs.Open sql,Conn,1,3
If rs.eof then
rs.addnew '会员第一次进入网站(可能从网站首页直接登录进入论坛)
rs("id")=session.sessionID
rs("name")=session("show") '写入用户昵称
rs("username")=session("username") '写入登录用户名
rs("online")=1 '表示用户已经登陆,是会员身份
rs("datetime")=now() '将当前系统时间设置为用户的登陆时间
userip = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
If userip = "" Then
userip= Request.ServerVariables("REMOTE_ADDR")
End if
rs("ip")=userip
Else '会员非第一次浏览网站,访客登录网站
rs("name")=session("show") 更新用户昵称
rs("username")=session("username")
rs("online")=1 '表示用户已经登陆,是会员身份
rs("datetime")=now()
End if
rs.update
rs.close
End if
Set rs=nothing
%>
conn.execute("delete from online where datediff('s',datetime,now())>60") '删除60秒没有活动的访客,时间可以自己调整
Set rs=Server.CreateObject("ADODB.Recordset")
If session("username")="" then 判断用户未登录
sql="select * from online where id='"&session.sessionid&"'" '判断这个sessionid是否存在于数据库表中
rs.Open sql,Conn,1,3
If rs.eof then '访客第一次浏览
rs.addnew
rs("id")=session.sessionID
rs("name")="游客"
rs("online")=0 '0表示用户未登陆,是游客身份
rs("datetime")=now()
userip = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
If userip = "" Then
userip= Request.ServerVariables("REMOTE_ADDR")
End if
rs("ip")=userip
Else '访客非第一次浏览
rs("datetime")=now() '更新活动时间
rs.update
rs.close
End if
Else
sql="select * from online where id='" & session.sessionID & "' or admin='"&session("username")&"'" '判断sessionid 或者 用户名记录已存在数据表中
rs.Open sql,Conn,1,3
If rs.eof then
rs.addnew '会员第一次进入网站(可能从网站首页直接登录进入论坛)
rs("id")=session.sessionID
rs("name")=session("show") '写入用户昵称
rs("username")=session("username") '写入登录用户名
rs("online")=1 '表示用户已经登陆,是会员身份
rs("datetime")=now() '将当前系统时间设置为用户的登陆时间
userip = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
If userip = "" Then
userip= Request.ServerVariables("REMOTE_ADDR")
End if
rs("ip")=userip
Else '会员非第一次浏览网站,访客登录网站
rs("name")=session("show") 更新用户昵称
rs("username")=session("username")
rs("online")=1 '表示用户已经登陆,是会员身份
rs("datetime")=now()
End if
rs.update
rs.close
End if
Set rs=nothing
%>
弊端:在线人数多时对数据库访问过于频繁,占用服务器资源;每个页面中都需调用,使用没有第一种方法方便;从某种意义上说,这种方法应称为统计活动用户更为合适,因为用户在设定的时间内如果没有任何操作将被视为不在线。
评论: 1 | 引用: 0 | 查看次数: 5693
发表评论
请登录后再发表评论!