我有一个 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 操作对用户进行身份验证,所以我正在做这样的事情:
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 过滤器后,继续执行 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()?