7

ユーザーが認証されていない場合にユーザーをサインインページに転送するCustomeAuthorizeアクションフィルターがあります。このフィルターをアクションまたはコントローラーに適用します。

[CustumeAuthorize]
public ActionResult MyAction()
{
   //do something here
   return View();
}

フィルタは次のようになります。

public class CustomAuthorizeAttribute : ActionFilterAttribute
{
    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {

        if (!currentUserIsAuthenticated)
        {

            filterContext.Result =
                new RedirectToRouteResult(
                    new RouteValueDictionary{{ "controller", "Account" },
                                                 { "action", "SignIn" },
                                                 { "returnUrl",    filterContext.HttpContext.Request.RawUrl }
                                                });
        }
        else
        {
            base.OnActionExecuting(filterContext);
        }
    }
}

filterContext.Resultに値を割り当てると、フィルターの実行が終了した後、実行は(どういうわけか?!)SignInアクションにリダイレクトされ、MyActionは実行されません。これはまさに私が欲しいものです。

ここで、CustomAuthorizeを変更して、自分のSignInアクションではなく、外部Webサイトに対してユーザーを認証するとします。そのため、次のようにします。

public class CustomAuthorizeAttribute : ActionFilterAttribute
{
    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {

        if (!currentUserIsAuthenticated)
        {
             filterContext.HttpContext.Response.Redirect("http://externalSite.com/login?returnUrl=" + filterContext.HttpContext.Request.RawUrl);
        }
        else
        {
            base.OnActionExecuting(filterContext);
        }
    }
}

私の問題は、CustomAuthorizeフィルターの2番目のバージョンの実行が終了した後、実行がMyActionに続くことです。これは、私が望んでいることではありません。この場合、フィルター後にMyActionの実行を停止するにはどうすればよいですか?

-更新-私はちょうど新しい問題に遭遇しました。私のMVCアプリケーションはiFrameにあり、リダイレクト後に現在のフレームをメインフレームとして強制するようにしたいので、次のようなことをしています。

string url = "http://externalSite.com/login?returnUrl=" + filterContext.HttpContext.Request.RawUrl;
filterContext.HttpContext.Response.Write("<script type=\"text/javascript\">\ntop.location.href = \"" + url + "\";</script>");

JavaScriptをRedirectResult()に渡す方法はありますか?

4

3 に答える 3

11

以前にRedirectToRouteResultを使用していたのと同様に、RedirectResultを使用して、フィルターコンテキストの結果を置き換えます。

filterContext.Result = new RedirectResult("http://externalSite.com/login?returnUrl=" + filterContext.HttpContext.Request.RawUrl );
于 2009-05-07T16:26:07.087 に答える
1

私が理解しているかどうかを見てみましょう-あなたはiFrameを持っていて、このiFrame内でアクションを実行しています。そのiFrame内ではなく、親ページにリダイレクトしたいですか?

その場合は、アクションでRedirect(url)を使用してください。

于 2011-10-21T00:09:42.797 に答える
0

ログインページでjQueryによる判断を追加できます。

$(function () {
        if (window != top) {
            top.location.href = location.href;
        }
    });   

また

アクション「OnActionExecuting」で「filterContext.Result」を編集します

filterContext.Result = new ContentResult() { Content = "<script>top.window.location.href='/user/Login'</script>" };
于 2017-08-14T07:57:32.870 に答える