此为孟老前辈写的一段代码!可是没有Cache清除,所以用户只能登陆一次就不发在登陆了,大家看看有上面好方法可以在用户点击退出按钮的时候清空Cache,我自己试了的,好像用Cache.remove(“sKey”);
没用啊!小弟不才在此请教各位前辈啊!!!该怎么弄
有没有点击退出按钮删除当前用户的Cache的办法啊!我自己没找到该方法。
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;namespace eMeng.Exam
{
/// <summary>
/// SingleLogin 的摘要说明。
/// 实现单点登录
/// </summary>
public class SingleLogin : System.Web.UI.Page
{
protected System.Web.UI.WebControls.TextBox UserName;
protected System.Web.UI.WebControls.TextBox PassWord;
protected System.Web.UI.WebControls.Label Msg;
protected System.Web.UI.WebControls.Button Login;private void Page_Load(object sender, System.EventArgs e)
{
  // 实际例子可访问:
  // http://dotnet.aspx.cc/Exam/SingleLogin.aspx
}#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
  InitializeComponent();
  base.OnInit(e);
}/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
  this.Login.Click += new System.EventHandler(this.Login_Click);
  this.Load += new System.EventHandler(this.Page_Load);
}
#endregionprivate void Login_Click(object sender, System.EventArgs e)
{
  // 作为唯一标识的Key,应该是唯一的,这可根据需要自己设定规则。
  // 做为测试,这里用用户名和密码的组合来做标识;也不进行其它的错误检查。  // 生成Key
  string sKey = UserName.Text + "_" + PassWord.Text;
  // 得到Cache中的给定Key的值
  string sUser = Convert.ToString(Cache[sKey]);
  // 检查是否存在
  if (sUser == null || sUser == String.Empty)
  {
    // Cache中没有该Key的项目,表名用户没有登录,或者已经登录超时
    // 注意下面使用的TimeSpan构造函数重载版本的方法,是进行是否登录判断的关键。
    TimeSpan SessTimeOut = new TimeSpan(0,0,System.Web.HttpContext.Current.Session.Timeout,0,0);
    HttpContext.Current.Cache.Insert(sKey,sKey,null,DateTime.MaxValue,SessTimeOut,
      System.Web.Caching.CacheItemPriority.NotRemovable,null);
    Session["User"] = sKey;
    // 首次登录,您可以做您想做的工作了。
    Msg.Text="<h4 style='color:red'>嗨!欢迎您访问<a href='http://dotnet.aspx.cc/'>【孟宪会之精彩世界】";
    Msg.Text += "</a>,祝您浏览愉快!:)</h4>";
  }
  else
  {
    // 在 Cache 中发现该用户的记录,表名已经登录过,禁止再次登录
    Msg.Text="<h4 style='color:red'>抱歉,您好像已经登录了呀:-(</h4>";
   return;
  }
}
}
}

解决方案 »

  1.   

    string sKey = UserName.Text + "_" + PassWord.Text;Cache.Remove(sKey);
      

  2.   

    也就是说, 你还要有个 APPLICATION 或 SESSION 或 VIEW 变量来保存 CACHE 的 KEY 才可以
      

  3.   

    CACHE 只是用来验证是否是单点登录,而不是用来做身份验证的,你要用其他方式做身份验证,退出时通过相应的方式退出
      

  4.   

    身份验证我作了。难点就在于这个登陆,每次登陆都只能登陆一次,因为有CACHE。
    Cache.Remove(sKey);单放在这个登陆页面可以用可是我的退出页面是做在首页上的,好像要传sKey过去,就是不知道怎么传。。昏!!!
      

  5.   

    身份验证我作了。难点就在于这个登陆,每次登陆都只能登陆一次,因为有CACHE。
    Cache.Remove(sKey);单放在这个登陆页面可以用,可我的退出按钮是做在首页上的,好像要传sKey过去,就是不知道怎么传。。昏!!!
      

  6.   

    我不是说了么?
    你还要有个 APPLICATION 或 SESSION 或 VIEW 变量来保存 CACHE 的 KEY 才可以