要求使用Application和Session对象统计登录人数
知道的高手写下~感激ing.

解决方案 »

  1.   

    一、利用Session和Application对象的OnStart、OnEnd事件这种方法是比较常见的,许多ASP书籍在介绍怎么统计在线人数时都是用这种方法。这种方法还得结合Global.asa,因为Session和Application对象的OnStart、OnEnd事件必须写在这里运行,典型的Global.asa内容如下: 程序代码<Script language="VBScript" runat="server">
    sub application_onstart
           application.lock
           application("online")=0
           application.unlock
    end Subsub session_onstart
           application.lock
           application("online") = application("online") + 1
           application.unlock
    end subsub session_onend
            application.lock
            application("online")=application("online")-1
            application.unlock
    end sub
    </Script>弊端:用户不是正常退出登录(调用Session.Abandon方法退出登录),如直接关闭浏览器、地址栏输入网址直接转到其他网站时Session的OnEnd事件不会马上被触发,需等Session存活时间到才会触发OnEnd事件。二、Session+数据库源码如下: 程序代码
    <%
    conn.execute("delete from online where datediff('s',datetime,now())>60")  '删除60秒没有活动的访客,时间可以自己调整
    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
    %>
    弊端:在线人数多时对数据库访问过于频繁,占用服务器资源;每个页面中都需调用,使用没有第一种方法方便;从某种意义上说,这种方法应称为统计活动用户更为合适,因为用户在设定的时间内如果没有任何操作将被视为不在线。
      

  2.   

    现在数据库中做一张以便存放,不然,要是iis重启,那么你的数据就归零了。至于在session和application中的代码,网上一大堆,插下就有,就是在begin和end中进行数据处理