--- title: View Based Authorization author: rick-anderson description: keywords: ASP.NET Core, ms.author: riande manager: wpickett ms.date: 10/14/2016 ms.topic: article ms.assetid: 24ce40d8-9b83-4bae-9d4c-a66350fcc8f8 ms.technology: aspnet ms.prod: asp.net-core uid: security/authorization/views --- # View Based Authorization Often a developer will want to show, hide or otherwise modify a UI based on the current user identity. You can access the authorization service within MVC views via [dependency injection](../../fundamentals/dependency-injection.md#fundamentals-dependency-injection). To inject the authorization service into a Razor view use the `@inject` directive, for example `@inject IAuthorizationService AuthorizationService` (requires `@using Microsoft.AspNetCore.Authorization`). If you want the authorization service in every view then place the `@inject` directive into the `_ViewImports.cshtml` file in the `Views` directory. For more information on dependency injection into views see [Dependency injection into views](../../mvc/views/dependency-injection.md). Once you have injected the authorization service you use it by calling the `AuthorizeAsync` method in exactly the same way as you would check during [resource based authorization](resourcebased.md#security-authorization-resource-based-imperative). ```csharp @if (await AuthorizationService.AuthorizeAsync(User, "PolicyName")) {

This paragraph is displayed because you fulfilled PolicyName.

} ``` In some cases the resource will be your view model, and you can call `AuthorizeAsync` in exactly the same way as you would check during [resource based authorization](resourcebased.md#security-authorization-resource-based-imperative); ```csharp @if (await AuthorizationService.AuthorizeAsync(User, Model, Operations.Edit)) {

Edit

} ``` Here you can see the model is passed as the resource authorization should take into consideration. >[!WARNING] >Do not rely on showing or hiding parts of your UI as your only authorization method. Hiding a UI element does not mean a user cannot access it. You must also authorize the user within your controller code.