CSDN首页 新闻 论坛 小组 Blog 文档 下载 读书 Tag 网摘 搜索 .NET Java 游戏 视频 人才 外包 第二书店 程序员
五一特色活动创意 征集,有重奖!!! "一句话,话优势 "可用分和程序员杂志等你来拿
CSDN社区
搜索 | 收藏 | 打印 | 关闭
CSDN社区 >  .NET技术 >  ASP.NET

百分求解!!如何监控用户的在线状态?

楼主keanu1978(黄金安魂曲)2004-12-18 22:34:48 在 .NET技术 / ASP.NET 提问

现在我希望实现如下功能:  
  用户如果在线,则不能使用相同的用户名和密码再次登录程序。我的设想是在数据库中增加一个字段,如果用户登录,则将该字段置为1,离开恢复为0。现在的问题是除非用户使用按钮退出,我可以修改数据库字段。否则如果用户直接关闭IE,我没法判断用户是否在线。请问各位有什么办法可以解决? 问题点数:100、回复次数:11Top

1 楼happyfamily(FreeHorse)回复于 2004-12-18 22:42:21 得分 20

这个没有很好的办法  
  把Session设置的时间小些,写一个触发事件凑合用吧Top

2 楼drone(雄蜂)回复于 2004-12-18 22:47:28 得分 0

通常的做法是将某个页面定时刷新或者回传来实现对客户端的状态监控的。Top

3 楼sykpboy(小憩---每天解决1个问题,顺便升星)回复于 2004-12-18 22:50:32 得分 0

you   can   use   Linux   &   php   instead.Top

4 楼Aimar168(跟着微软走,牵着太阳的手)回复于 2004-12-18 22:57:03 得分 0

建一个online表记录在线用户  
  定时删除一定时间内不活动的用户  
  这个web版块很多人提问过,去那搜搜Top

5 楼deng1107(游戏人间(.net))回复于 2004-12-19 01:45:39 得分 0

可以在Global.asax中实现Top

6 楼webserv2(New life New job)回复于 2004-12-19 02:22:26 得分 0

没有好方法   !只能定时刷新   或者用session   超时Top

7 楼pandahyang(偶在学习.NET)回复于 2004-12-19 12:12:30 得分 0

用一个框架嵌套,在框架页里面写onUnload=“触发事件”,然后改写数据库中的标志就可以了,这样就可以防止他直接关掉ie的问题了Top

8 楼precipitant(塞北的雪)回复于 2004-12-19 12:29:51 得分 30

用application存储用户在线列表,通过session_onend事件来删除该用户的在线信息,用户登录时检查application列表中是否包含该用户的登录信息,如果没有,则允许登录,然后将登录信息记录到application中。  
   
  Top

9 楼goody9807(http://goody9807.cnblogs.com)回复于 2004-12-19 13:53:12 得分 50

/*  
          本文属作者原创,请尊重作者劳动成功,转载和使用注明出处  
          作者:子扬  
          联系方式:QQ:21112856  
          网站:www.25bz.com  
          MSN:   zjgzkq(at)hotmail(dot)com  
  */  
   
  一、原理  
  在.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();  
  }  
   
  Top

10 楼zyq1215(小芸)回复于 2004-12-19 15:54:03 得分 0

我用的方法和楼上相似,楼主可以一试Top

11 楼online2005(大山)回复于 2004-12-19 16:08:19 得分 0

有没有想过用js   调用Web服务   
  可集成多种功能  
  就像给网站装备了监视器    
   
  Top

相关问题

  • 用户权限管理!重分求解
  • 用户自定义算术表达式的求解
  • 求解数据库中的用户与组的相关问题
  • -------------NT的用户管理问题 高分求解-------------
  • 用户的特殊要求,100求解 着急!
  • 高分求解,得分很容易的哟,来者都有分!!常见问题求解--用户权限指派
  • 求解 求解 求解
  • 高分求解:c/s、5.0.9,用户邮箱在持续打开状态下,minder弹出邮件提示有新邮件,如果长时间不处理,就会notes死掉,及时处理,不会死掉!
  • 求解??
  • 求解?

关键词

  • 用户
  • 字段
  • 数据库
  • 作者
  • application
  • 信息
  • ip
  • uson
  • 访问
  • struserid

得分解答快速导航

  • 帖主:keanu1978
  • happyfamily
  • precipitant
  • goody9807

相关链接

  • CSDN .NET频道
  • .NET类图书
  • C#类图书
  • .NET类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
世纪乐知(北京)网络技术有限公司 版权所有, 京 ICP 证 020026 号
北京创新乐知广告有限公司 提供技术支持
Copyright © 2000-2007, CSDN.NET, All Rights Reserved
GongshangLogo