zoukankan      html  css  js  c++  java
  • 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秒没有活动的访客,时间可以自己调整。

    申明

    非源创博文中的内容均收集自网上,若有侵权之处,请及时联络,我会在第一时间内删除.再次说声抱歉!!!

    博文欢迎转载,但请给出原文连接。

  • 相关阅读:
    windows系统调用 互斥体mutex
    windows系统调用 利用事件对象实现进程通信
    windows系统调用 调度优先级
    <十四>JDBC_c3p0数据库连接池
    <十三>JDBC_dbcp数据库连接池
    <十二>JDBC_批量处理
    <十一>JDBC_事务的处理+隔离
    <十>JDBC_处理Blob类型数据
    <八>JDBC_重构DAO查询方法
    <七>JDBC_使用beanutils工具类操作javaBean
  • 原文地址:https://www.cnblogs.com/Athrun/p/1126375.html
Copyright © 2011-2022 走看看