ASP.NET MVC: Can I say [Authorize Roles=“Administrators”] on the Controller class, but have one public action?

前端 未结 3 1684
天命终不由人
天命终不由人 2021-01-13 04:24

I started off using the default project\'s AccountController, but I\'ve extended/changed it beyond recognition. However, in common with the original I have a

相关标签:
3条回答
  • 2021-01-13 04:50

    To override an controller Attribute at the Action level you have to create a custom Attribute and then set the Order property of your custom attribute to a higher value than the controller AuthorizeAttribute. I believe both attributes are then still executed unless your custom attribute generates a result with immediate effect such as redirecting.

    See Overriding controller AuthorizeAttribute for just one action for more information.

    So I believe in your case you will just have to add the AuthorizeAttribute on the Actions and not at the controller level. You could however create a unit test to ensure that all Actions (apart from LogOn) have an AuthorizeAttribute

    0 讨论(0)
  • 2021-01-13 05:04

    After way too much time, I came up with a solution.

    public class OverridableAuthorize : AuthorizeAttribute
    {
        public override void OnAuthorization(AuthorizationContext filterContext)
        {
            var action = filterContext.ActionDescriptor;
            if(action.IsDefined(typeof(IgnoreAuthorization), true)) return;
    
            var controller = action.ControllerDescriptor;
            if(controller.IsDefined(typeof(IgnoreAuthorization), true)) return;
    
            base.OnAuthorization(filterContext);
        }
    }
    

    Which can be paired with IgnoreAuthorization on an Action

    public class IgnoreAuthorization : Attribute
    {
    }
    
    0 讨论(0)
  • 2021-01-13 05:07

    You can use AuthorizeAttribute on your class

    http://msdn.microsoft.com/en-us/library/system.web.mvc.authorizeattribute.aspx

    For relaxing you can implement for example a custom action filter attribute like this (I didn' test if it works).

    public class GetRidOfAutorizationAttribute : AuthorizeAttribute 
    {
    public override void OnAuthorization(AuthorizationContext filterContext)
    {
    
    // you can for example do nothing
    filterContext.Result = new EmptyResult(); 
    
    }
    }
    
    0 讨论(0)
提交回复
热议问题