我在我的LoginControl.ascx代码后面有这个:
protected void Logout_Click(object sender, EventArgs e)
{
FormsAuthentication.SignOut();
Session.Abandon();
FormsAuthentication.RedirectToLoginPage();
Response.End;
//Response.Redirect("default.aspx");
}
我预计在注销时,用户将被重定向到登录页面(在本例中为default.aspx),并且会附加 NO 查询字符串。相反,我在URL上看到的是:
http://kab.domain.com/default.aspx?ReturnUrl=%2fAdministration%2fCharacter%2fView.aspx
现在,在注销后,我想以另一个人身份登录(权限较少),并且在成功登录后,它会将我重定向到这个新登录无权查看的页面! < grrr />
我意识到“普通”用户永远不会遇到这个问题,但测试用户会这样做,就他们而言,这是一个错误。
即使使用Response.Redirect,我仍然可以获得查询字符串。如何在logout ???
中删除查询字符串答案 0 :(得分:0)
试试这个:
Response.Redirect(FormsAuthentication.LoginUrl);
答案 1 :(得分:-1)
public partial class MasterPage : System.Web.UI.MasterPage
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void signout_Click(object sender, EventArgs e)
{
Response.Write("<script language=javascript>var wnd=window.open('','newWin','height=1,width=1,left=900,top=700,status=no,toolbar=no,menubar=no,scrollbars=no,maximize=false,resizable=1');</script>");
Response.Write("<script language=javascript>wnd.close();</script>");
Response.Write("<script language=javascript>window.open('login.aspx','_parent',replace=true);</script>");
Session["name"] = null;
}
}
我也在这个代码的所有页面上添加。
protected void Page_Load(object sender, EventArgs e)
{
Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.Cache.SetAllowResponseInBrowserHistory(false);
}
}