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