//实现思路
//利用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;
}
}
利用Cache功能实现站点单点登录 防重复登录
本文转载:CSDN博客