asp实现通过session来统计在线人数的方法

来源:asp之家 时间:2007-08-13 12:56:00 

内容摘要:统计在线人数的方法很多,可以使用Application来统计在线人数,也可以使用IP来统计在线人数。各有优点。本文介绍了通过判断Session来统计在线人数的方法,该方法的好处是可以统计一个IP上的不同访客。因为很多时候可能有好几台电脑共用一个IP。

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

 1.建立数据库表
  表名为online
  设如下字段
  id '用来记录每一个访问都的session.sessionid
  name '如果是访客,则记录为访客。
  online  '如果是访各为0 如果是会员1
  datetime '最近活动时间
  username '会员的登录用户名,访客为空。
  ip '记录访问都的登录IP

2.实现统计的asp代码

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

相关阅读:

asp使用Application来统计在线人数方法

使用IP地址来统计在线人数方法

标签:在线人数,session,统计
0
投稿

猜你喜欢

  • python列表元素拼接成字符串的4种方法

    2021-10-02 23:59:59
  • Python实现ping指定IP的示例

    2023-10-05 04:20:10
  • mysql 实现添加时间自动添加更新时间自动更新操作

    2024-01-14 15:58:59
  • python中decimal模块的用法

    2021-01-20 06:54:57
  • vue新玩法VueUse工具库具体用法@vueuse/core详解

    2023-07-02 16:55:44
  • Go语言实现二进制与十进制互转的示例代码

    2024-02-08 09:31:15
  • MySQL 替换某字段内部分内容的UPDATE语句

    2024-01-22 17:45:49
  • Win2008中安装的MSSQL2005后无法访问的解决方法

    2024-01-21 03:57:57
  • python pygame实现五子棋双人联机

    2022-04-12 22:41:04
  • 使用python+Flask实现日志在web网页实时更新显示

    2021-03-15 10:16:30
  • 出现“不能执行已释放的Script代码”错误的原因及解决办法

    2024-04-19 10:02:13
  • 解决python执行不输出系统命令弹框的问题

    2022-10-01 10:25:02
  • Vue中使用stylus报错的解决

    2024-05-02 17:03:55
  • python通过opencv调用摄像头操作实例分析

    2023-03-09 14:32:04
  • SQL Server数据表压缩

    2024-01-25 21:47:12
  • Python装饰器使用接口测试的步骤

    2021-03-27 11:39:06
  • 八大排序算法的Python实现

    2023-08-02 16:09:31
  • 在go中使用omitempty的代码实例

    2024-04-25 15:12:47
  • PyQt与pycharm的结合使用教程

    2022-09-08 06:47:05
  • 深入理解ES6的迭代器与生成器

    2024-04-29 13:36:18
  • asp之家 网络编程 m.aspxhome.com