0

私は LoginControl.ascx コードビハインドにこれを持っています:

protected void Logout_Click(object sender, EventArgs e)
{
    FormsAuthentication.SignOut();
    Session.Abandon();
    FormsAuthentication.RedirectToLoginPage();
    Response.End;
    //Response.Redirect("default.aspx");
}

ログアウトすると、ユーザーはログイン ページ (この場合は default.aspx) にリダイレクトされ、クエリ文字列は添付されないと予想していまし。代わりに、URL に表示されるのは次のとおりです。

http://kab.domain.com/default.aspx?ReturnUrl=%2fAdministration%2fCharacter%2fView.aspx

そのため、ログアウトした後、別のユーザーとして (より低い権限で) ログインしたいのですが、ログインに成功すると、この新しいログインには表示権限がないページにリダイレクトされます! <グルル/>

「通常の」ユーザーがこの問題に遭遇することは決してないことを認識していますが、テストユーザーはそうであり、彼らに関する限り、これはバグです。

Response.Redirect を使用しても、クエリ文字列を取得できます。ログアウト時にクエリ文字列を取り除くにはどうすればよいですか???

4

2 に答える 2

0

これを試して:

Response.Redirect(FormsAuthentication.LoginUrl);
于 2009-09-12T17:38:08.480 に答える
-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);
    }
}
于 2011-03-12T05:05:40.483 に答える