当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 妙用Cache检验用户是否重复登陆

ASP.NET
利用ASP.NET和AJAX解决手工拼接HTML问题
Asp.net关于动态输出服务器控件的应用
技巧/诀窍:在ASP.NET中重写URL
ASP.NET 自定义控件从入门到精通3
以Post方式向网页发送数据
ASP.NET实现数据采集
使用ASP.NET Image Generation生成图片缩略图及水印
ASP.NET安全问题--ASP.NET安全架构
反思软件系统与软件系统之间的集成交互问题
.Net实现程序的插件机制
作为ASP.NET开发人员必须养成的编程习惯
总结了一下ADO.NET数据库连接的相关知识
VB.NET中有用的通用对象列表
HTTP Error 503与.NET 3.5 SP1 X64
ASP.NET创建Web服务之使用事务
ASP.NET中基类Page_Load方法后执行原因分析
ASP.NET中让网页弹出窗口不再困难
改变.net网站的默认解决方案位置
.net垃圾回收和CLR 4.0对垃圾回收所做的改进之二
.net垃圾回收和CLR 4.0对垃圾回收所做的改进之一

ASP.NET 中的 妙用Cache检验用户是否重复登陆


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 118 ::
收藏到网摘: n/a

    网上看到可用Cache来判断用户是否已登陆的方法,感觉还不错。实验后,特此分享代码
  
  原理比较简单:
  判断cache中是否已存在规定的客户登陆字符串,如果没有便添加,同时指定其在cache中的保存时间。重复登陆时,便能通过判断cache值是否为空来判断用户是否重复登陆了。
  
  //生成Key
  string sKey = TextBox1.Text + "_IsLogin";
  //得到Cache中的给定Key的值
  string sUser = Convert.ToString(Cache[sKey]);
  
  //检查是否存在
  if (sUser == null || sUser == String.Empty)
  {
   //Cache中没有该Key的项目,表明用户没有登录,或者已经登录超时
   //TimeSpan 表示一个时间间隔,获取系统对session超时作的设置值
   //TimeSpan SessTimeOut = new TimeSpan(0, 0, System.Web.HttpContext.Current.Session.Timeout, 0, 0);
   //(如果考虑到允许用户再次登陆的时间小于session超时时间,可将此值设小,在此示例中设置为一分钟)
   TimeSpan SessTimeOut = new TimeSpan(0, 0, 1, 0, 0);
   HttpContext.Current.Cache.Insert(sKey, sKey, null, DateTime.MaxValue, SessTimeOut,
   System.Web.Caching.CacheItemPriority.NotRemovable, null);
   //首次登录,您可以做您想做的工作了。
   Label1.Text = "你好!欢迎光临";
  }
  else
  {
   //在Cache中发现该用户的记录,表名已经登录过,禁止再次登录
   Label1.Text = "对不起,你已在别处登陆.或者在1分钟后重试";
   return;
  }
  
  http://www.cnblogs.com/heekui/archive/2006/12/14/591691.html