asp论坛在线人数统计研究

asp论坛在线人数统计研究

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

有兴趣和意见的朋友可以发信到qizulovemin@hotmail.com,希望和各位老师交流学习。 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值