asp论坛在线人数统计

一个在线统计访会员的功能,感觉用的方法能比较准确的统计在线人数。当然一定也有不足的地方,希望各位纠正。

特别说明:

本论坛登录是采用用户名登录,登录后取得用户昵称。整个网站不显示用户名,我想相对来说安全一点吧,所以有昵称和用户名区别。

1。建立数据库表

表名为online

设如下字段

id '用来记录每一个访问都的session.sessionid

name '如果是访客,则记录为访客。

online  '如果是访各为0 如果是会员1

datetime '最近活动时间

username '会员的登录用户名,访客为空。

ip '记录访问都的登录IP

head.asp '向数据库表写入在线人数,该页面必须搜入到每一个用于浏览ASP页面中。

<%

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秒没有活动的访客,时间可以自己调整。