如何显示在线人数和所在位置[转]

一、原理
            在.net中的global.asax中有Application_AuthenticateRequest事件和Application_BeginRequest事件是在每次访问aspx文件都会触发。但是Application_BeginRequest中不能对已经经过FROMS身份验证的身份ticket票进行识别。所以只能放到Application_AuthenticateRequest中去。
            我的实现原理是:每次访问aspx文件时候都会判断在线表里面是否有这个用户(已经登录了的记录用户名,没有登录的记录IP地址),如果不存在,则将该用户的身份、最后访问时间、最后访问IP、和最后访问的URL存入数据库。如果数据库中已经曾在,则更新该记录,把最后访问时间,IP以及最后访问URL更新。
            同时,删除数据库中与当前时间间隔20分钟以上的数据(20分钟没操作当为超时)。
            二、优点
            这样,你不仅仅可以看到当前在线的准确人数,还知道是那些人在线,以及是否登陆,和访问人数中已经是会员的比例,以及所在位置,并计算某个页上的人数。
            三、数据库结构:
            主键    字段            类型    长度    是否为空说明
            1uson_serialint40序号
            0uson_uservarchar200用户名(没登陆则为IP)
            0uson_companyvarchar1000公司名(没登陆则为'游客')
            0uson_ip        varchar200IP地址
            0uson_datedatetime80最后操作时间
            0uson_urlvarchar1000最后操作页面路径
            四、程序
            注意:
            1、程序位于global.asax中
            2、我是使用的FORMS身份验证
            3、请using System.Web.Security
            protected void Application_AuthenticateRequest(Object sender,
            EventArgs e)
            {
            string strUserID = string.Empty;
            string strCompany = string.Empty;
            if (Request.IsAuthenticated)
            {
            FormsIdentity identity = (FormsIdentity)User.Identity;
            FormsAuthenticationTicket ticket = identity.Ticket;
            strUserID = User.Identity.Name;
            strCompany = ticket.UserData.Split("|".ToCharArray())[2];
            }
            else
            {
            strUserID = Request.UserHostAddress;
            strCompany = "游客";
            }
            MemberOnlineInfo objOnline = new MemberOnlineInfo(strUserID,
            Request.UserHostAddress, DateTime.Now.ToString(), Request.FilePath,
            strCompany);
            MemberAccount account = new MemberAccount();
            if (!account.CheckUserOnline(strUserID))
            account.AddOnline(objOnline);
            else
            account.UpdateOnline(objOnline);
            //删除超时的会员
            account.DeleteOnline();
            }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值