AspNetCore.Docs/aspnetcore/security/authorization/roles.md

125 lines
4.1 KiB
Markdown
Raw Normal View History

2016-10-29 01:35:15 +08:00
---
title: Role-based authorization in ASP.NET Core
2016-10-29 01:35:15 +08:00
author: rick-anderson
description: Learn how to restrict ASP.NET Core controller and action access by passing roles to the Authorize attribute.
2016-10-29 01:35:15 +08:00
manager: wpickett
2018-01-29 23:21:31 +08:00
ms.author: riande
2016-10-29 01:35:15 +08:00
ms.date: 10/14/2016
ms.prod: asp.net-core
2018-01-29 23:21:31 +08:00
ms.technology: aspnet
ms.topic: article
2016-10-29 01:35:15 +08:00
uid: security/authorization/roles
---
# Role-based authorization in ASP.NET Core
2016-10-29 01:35:15 +08:00
2017-10-14 04:50:30 +08:00
<a name="security-authorization-role-based"></a>
2016-10-29 01:35:15 +08:00
When an identity is created it may belong to one or more roles. For example, Tracy may belong to the Administrator and User roles whilst Scott may only belong to the User role. How these roles are created and managed depends on the backing store of the authorization process. Roles are exposed to the developer through the [IsInRole](https://docs.microsoft.com/dotnet/api/system.security.principal.genericprincipal.isinrole) method on the [ClaimsPrincipal](https://docs.microsoft.com/dotnet/api/system.security.claims.claimsprincipal) class.
2016-10-29 01:35:15 +08:00
## Adding role checks
Role-based authorization checks are declarative&mdash;the developer embeds them within their code, against a controller or an action within a controller, specifying roles which the current user must be a member of to access the requested resource.
2016-10-29 01:35:15 +08:00
For example, the following code limits access to any actions on the `AdministrationController` to users who are a member of the `Administrator` role:
2016-10-29 01:35:15 +08:00
2016-11-18 13:03:07 +08:00
```csharp
2016-10-29 01:35:15 +08:00
[Authorize(Roles = "Administrator")]
public class AdministrationController : Controller
{
}
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
You can specify multiple roles as a comma separated list:
2016-10-29 01:35:15 +08:00
2016-11-18 13:03:07 +08:00
```csharp
2016-10-29 01:35:15 +08:00
[Authorize(Roles = "HRManager,Finance")]
public class SalaryController : Controller
{
}
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
This controller would be only accessible by users who are members of the `HRManager` role or the `Finance` role.
If you apply multiple attributes then an accessing user must be a member of all the roles specified; the following sample requires that a user must be a member of both the `PowerUser` and `ControlPanelUser` role.
2016-11-18 13:03:07 +08:00
```csharp
2016-10-29 01:35:15 +08:00
[Authorize(Roles = "PowerUser")]
[Authorize(Roles = "ControlPanelUser")]
public class ControlPanelController : Controller
{
}
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
You can further limit access by applying additional role authorization attributes at the action level:
2016-10-29 01:35:15 +08:00
2016-11-18 13:03:07 +08:00
```csharp
2016-10-29 01:35:15 +08:00
[Authorize(Roles = "Administrator, PowerUser")]
public class ControlPanelController : Controller
{
public ActionResult SetTime()
{
}
[Authorize(Roles = "Administrator")]
public ActionResult ShutDown()
{
}
}
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
In the previous code snippet members of the `Administrator` role or the `PowerUser` role can access the controller and the `SetTime` action, but only members of the `Administrator` role can access the `ShutDown` action.
You can also lock down a controller but allow anonymous, unauthenticated access to individual actions.
2016-11-18 13:03:07 +08:00
```csharp
2016-10-29 01:35:15 +08:00
[Authorize]
public class ControlPanelController : Controller
{
public ActionResult SetTime()
{
}
[AllowAnonymous]
public ActionResult Login()
{
}
}
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
2017-10-14 04:50:30 +08:00
<a name="security-authorization-role-policy"></a>
2016-10-29 01:35:15 +08:00
## Policy based role checks
2017-02-02 13:04:51 +08:00
Role requirements can also be expressed using the new Policy syntax, where a developer registers a policy at startup as part of the Authorization service configuration. This normally occurs in `ConfigureServices()` in your *Startup.cs* file.
2016-10-29 01:35:15 +08:00
2016-11-18 13:03:07 +08:00
```csharp
2016-10-29 01:35:15 +08:00
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc();
services.AddAuthorization(options =>
{
options.AddPolicy("RequireAdministratorRole", policy => policy.RequireRole("Administrator"));
});
}
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
Policies are applied using the `Policy` property on the `AuthorizeAttribute` attribute:
2016-10-29 01:35:15 +08:00
2016-11-18 13:03:07 +08:00
```csharp
2016-10-29 01:35:15 +08:00
[Authorize(Policy = "RequireAdministratorRole")]
public IActionResult Shutdown()
{
return View();
}
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
If you want to specify multiple allowed roles in a requirement then you can specify them as parameters to the `RequireRole` method:
2016-10-29 01:35:15 +08:00
2016-11-18 13:03:07 +08:00
```csharp
2016-10-29 01:35:15 +08:00
options.AddPolicy("ElevatedRights", policy =>
policy.RequireRole("Administrator", "PowerUser", "BackupAdministrator"));
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
This example authorizes users who belong to the `Administrator`, `PowerUser` or `BackupAdministrator` roles.