Я использую настраиваемый фильтр авторизации, как показано ниже:
public class ActionAuthorizeAttribute : AuthorizeAttribute {
protected override bool AuthorizeCore(System.Web.HttpContextBase httpContext) {
if(!httpContext.User.Identity.IsAuthenticated)
return false;
if(IsUserExcluded())
return false;
else
return IsRoleAuthorize(httpContext);
}
}
Я использую этот фильтр в верхней части каждого действия, которое у меня есть, а для проверки авторизовано требуется имя действия, имя контроллера и имя области. Так есть ли способ получить эти имена в AuthorizeCore()
методе, таком как System.Web.HttpContextBase
? если ответ отрицательный, то как я могу получить эти имена и передать их атрибуту, очевидно, я не хочу добавлять каждое имя вручную, на самом деле что-то вроде ViewContext.RouteData.Values["Controller"]
в контроллерах:
[ActionAuthorize(actionName=Action, controller=ControllerName, area=AreaName)]
public ActionResult Index() {
return View();
}
Кто-нибудь знает об этом?