【发布时间】:2015-11-27 11:39:01
【问题描述】:
对于我的 mvc5 项目,我已经实现了默认标识,但根据要求对其进行了更改。现在我想将未经授权的用户重定向到我创建的视图。我创建了一个自定义授权过滤器。当未经授权的用户进入时,它会出现在我的错误视图中。我可以通过 URL 识别它。但问题是它没有在视图中显示内容。相反,它显示 HTTP 404 错误。我把我的代码放在下面。我知道这已经在这里被问过好几次了。但我仍然无法解决它。所有帮助表示赞赏。提前致谢!
public class CustomAuthorize : AuthorizeAttribute
{
protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)
{
if (!filterContext.HttpContext.User.Identity.IsAuthenticated)
{
base.HandleUnauthorizedRequest(filterContext);
}
else
{
filterContext.Result = new RedirectToRouteResult(new
RouteValueDictionary(new { controller = "Error", action = "AccessDenied" }));
}
}
}
错误控制器
public class ErrorController : Controller
{
// GET: Error
public ActionResult Index()
{
return View();
}
public ActionResult AccessDenied()
{
return View();
}
}
拒绝访问视图
<h2>AccessDenied</h2>
Access Denied
在特定的控制器上
[CustomAuthorize(Roles = "Admin")]
public class ProductTypeController : Controller
{
}
我得到错误
HTTP 404。您要查找的资源(或其依赖项之一)可能已被删除、名称已更改或暂时不可用。请检查以下 URL 并确保其拼写正确。
更新问题
现在我想将未经授权的用户重定向到 ErrorView 并将未经身份验证的用户重定向到登录页面。我已将修改后的 CustomAuthorise 放在下面。但它不起作用。请指导我..
public class CustomAuthorize : AuthorizeAttribute
{
protected override bool AuthorizeCore(HttpContextBase httpContext)
{
if (!httpContext.Request.IsAuthenticated)
return false;
else
return true;
}
protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)
{
filterContext.Result = new RedirectToRouteResult(new
RouteValueDictionary(new { controller = "Error", action = "AccessDenied" }));
}
}
【问题讨论】:
标签: asp.net-mvc asp.net-mvc-5 asp.net-identity asp.net-identity-2 authorize-attribute