//实现思路 //利用Cache的功能,把用户的登录信息保存在Cache中,并设置过期时间为Session失效的时间,因此,一旦Session失效,Cache也过期;而Cache对所有的用户都可以访问,因此,用它保存用户信息比数据库来得方便。 //代码如下 : public void btnSubmit_Click(object sender, System.EventArgs e)//页面登陆提交按钮 { if (Page.IsValid == true) { if (IsLogin(Name, RealName)) Response.Redirect("css/error.aspx?" + "&ErrorMessage=" + "用户已经登录,请重新输入!"); } } /// <summary> /// 实现单点登录 /// </summary> /// <param name="UserCode"> 用户代码 </param> /// <param name="UserName"> 用户名称 </param> /// <returns> true 已经登录/ false 未登录 </returns> private bool IsLogin(string UserCode, string UserName) { string ExistsUser = Convert.ToString(Cache[UserCode]); if (ExistsUser == null || ExistsUser == String.Empty) { TimeSpan SessTimeOut = new TimeSpan(0, 0, System.Web.HttpContext.Current.Session.Timeout, 0, 0); HttpContext.Current.Cache.Insert(UserCode, UserName, null, DateTime.MaxValue, SessTimeOut, System.Web.Caching.CacheItemPriority.NotRemovable, null); return false; } else { return true; } }