sno*_*s74 3 c# authorize-attribute
我需要允许多个角色在C#Web API的控制器中访问方法。
I have a custom AuthorizeAttribute which takes an enum of role type, how can I make it so it accepts multiple enums ie. a variable length array of enums.
This is the code I have written for the Attribute:
private readonly RoleEnum roleInApplication;
public ScopeAuthorizeAttribute(RoleEnum roleInApplication)
{
this.roleInApplication = roleInApplication;
}
public override void OnAuthorization(HttpActionContext actionContext)
{
base.OnAuthorization(actionContext);
.......
var relatedPermisssionRole = (db call to get the rolename..etc)
RoleEnum role;
if (Enum.TryParse(relatedPermisssionRole, out role) && role == roleInApplication)
{
// Succeed if the scope array contains the required scope
return;
}
}
HandleUnauthorizedRequest(actionContext);
}
Run Code Online (Sandbox Code Playgroud)
And in the controller, I use it like this:
[ScopeAuthorize(RoleEnum.ADMIN)]
public async Task<IHttpActionResult> Create(MyModel model)
Run Code Online (Sandbox Code Playgroud)
How do I allow multiple roles? eg.
[ScopeAuthorize(RoleEnum.ADMIN, RoleEnum.USER)]
public async Task<IHttpActionResult> Create(MyModel model)
Run Code Online (Sandbox Code Playgroud)
You could use params as in public ScopeAuthorizeAttribute(params RoleEnum[] roleInApplication) but in reality you are trying to solve the issue in the wrong way, consider using Flags instead:
[FlagsAttribute]
enum Role
{
None = 0,
Admin = 1,
User = 2,
SomeOtherRole = 4
}
Run Code Online (Sandbox Code Playgroud)
Then you can pass your roles as one parameter using bitwise OR:
[ScopeAuthorize(Role.Admin | Role.User)]
public async Task<IHttpActionResult> Create(MyModel model)
Run Code Online (Sandbox Code Playgroud)
But don't just copy my code snippet, it is definitely worth having a good read of the documentation for Flags esp. Guidelines for FlagsAttribute and Enum to ensure you use this pattern correctly. There are a few caveats you must be aware of, which are not immediately obvious. It will be a 5 minutes well spent.
Also, I suggest you refrain from suffixing your enum with the word Enum and using UPPERCASE for your enum names.
| 归档时间: |
|
| 查看次数: |
101 次 |
| 最近记录: |