您好,欢迎来到思海网络,我们将竭诚为您提供优质的服务! 诚征网络推广 | 网站备案 | 帮助中心 | 软件下载 | 购买流程 | 付款方式 | 联系我们 [ 会员登录/注册 ]
促销推广
客服中心
业务咨询
有事点击这里…  531199185
有事点击这里…  61352289
点击这里给我发消息  81721488
有事点击这里…  376585780
有事点击这里…  872642803
有事点击这里…  459248018
有事点击这里…  61352288
有事点击这里…  380791050
技术支持
有事点击这里…  714236853
有事点击这里…  719304487
有事点击这里…  1208894568
有事点击这里…  61352289
在线客服
有事点击这里…  531199185
有事点击这里…  61352288
有事点击这里…  983054746
有事点击这里…  893984210
当前位置:首页 >> 技术文章 >> 文章浏览
技术文章

ASP.NET 防止同一用户重复登陆

添加时间:2014-12-18 20:02:14  添加: 思海网络 

要防止同一用户同时登陆,首页应该记录在线用户的信息(这里与用户名为例),然后判断正在登陆的用户里面是否已存在。在这里使用一个cache存放已经登陆的用户名,但是还有一个问题就是要知道用户是什么时候离开系统的呢?这就要定期清除cache中的内容了,也就是设置一个cache的时间。这个时间可以跟用户的session值联系起来,刚好当用户session值失效的时候该用户在cache里面的信息也会被清空.这样就达到了防止同时登陆的效果,具体代码如下: 

放在登陆成功的地方:
 

  1. string key = TextBox1.Text; //用户名文本框设为cache关键字 
  2. string uer = Convert.ToString(Cache[key]); //读取cache中用户相应的值 
  3. //判断cache中是否有用户的信息,如果没有相关的值,说明用户未登陆 
  4. if (uer == null  uer == String.Empty) 
  5.  //定义cache过期时间 
  6.  
  7.  TimeSpan SessTimeout = new TimeSpan(0, 0, System.Web.HttpContext.Current.Session.Timeout, 0, 0); 
  8.  
  9.  //第一次登陆的时候插入一个用户相关的cache值, 
  10.  HttpContext.Current.Cache.Insert(key, key, null, DateTime.MaxValue,SessTimeout, System.Web.Caching.CacheItemPriority.NotRemovable, null); 
  11.  Session["ADMINID"] = TextBox1.Text; 
  12.  Response.Redirect("main.ASPx"); 
  13. else 
  14.  //重复登陆 
  15.  Response.Write("<>alert('您的账号已经登陆!');window.location='login.aspx';</>"); 
  16. }  
  17. 关键字:ASP.NET、登陆、用户
分享到:

顶部 】 【 关闭
版权所有:佛山思海电脑网络有限公司 ©1998-2022 All Rights Reserved.
联系电话:(0757)22630313、22633833
公司地址: 广东省佛山市顺德区大良国际商业城A区4座3楼106号   邮编:528300
中华人民共和国增值电信业务经营许可证: 粤B1.B2-20030321 备案号:粤B2-20030321-1
网站公安备案编号:44060602000007 交互式栏目专项备案编号:200303DD003  
察察 工商 网安 举报有奖  警警  手机打开网站