7.5 KiB
title | author | ms.author | manager | ms.date | ms.topic | ms.assetid | ms.prod | uid |
---|---|---|---|---|---|---|---|---|
Introduction to Identity | rick-anderson | riande | wpickett | 10/14/2016 | article | cf119f21-1a2b-49a2-b052-547ccb66ee83 | aspnet-core | security/authentication/identity |
Introduction to Identity
By Pranav Rastogi, Rick Anderson, Tom Dykstra, Jon Galloway and Erik Reitan
ASP.NET Core Identity is a membership system which allows you to add login functionality to your application. Users can create an account and login with a user name and password or they can use an external login providers such as Facebook, Google, Microsoft Account, Twitter and more.
You can configure ASP.NET Core Identity to use a SQL Server database to store user names, passwords, and profile data. Alternatively, you can use your own persistent store to store data in another persistent storage, such as Azure Table Storage.
Overview of Identity
In this topic, you'll learn how to use ASP.NET Core Identity to add functionality to register, log in, and log out a user. You can follow along step by step or just read the details. For more detailed instructions about creating apps using ASP.NET Core Identity, see the Next Steps section at the end of this article.
-
Create an ASP.NET Core Web Application project in Visual Studio with Individual User Accounts.
In Visual Studio, select File -> New -> Project. Then, select the ASP.NET Web Application from the New Project dialog box. Continue by selecting an ASP.NET Core Web Application with Individual User Accounts as the authentication method.
The created project contains the
Microsoft.AspNetCore.Identity.EntityFrameworkCore
package, which will persist the identity data and schema to SQL Server using Entity Framework Core.[!NOTE] In Visual Studio, you can view NuGet packages details by selecting Tools -> NuGet Package Manager -> Manage NuGet Packages for Solution. You also see a list of packages in the dependencies section of the project.json file within your project.
The identity services are added to the application in the
ConfigureServices
method in theStartup
class:[!code-csharpMain]
These services are then made available to the application through dependency injection.
Identity is enabled for the application by calling
UseIdentity
in theConfigure
method of theStartup
class. This adds cookie-based authentication to the request pipeline.[!code-csharpMain]
For more information about the application start up process, see Application Startup.
-
Creating a user.
Launch the application from Visual Studio (Debug -> Start Debugging) and then click on the Register link in the browser to create a user. The following image shows the Register page which collects the user name and password.
When the user clicks the Register link, the
UserManager
andSignInManager
services are injected into the Controller:[!code-csharpMain]
Then, the Register action creates the user by calling
CreateAsync
function of theUserManager
object, as shown below:[!code-csharpMain]
-
Log in.
If the user was successfully created, the user is logged in by the
SignInAsync
method, also contained in theRegister
action. By signing in, theSignInAsync
method stores a cookie with the user's claims.[!code-csharpMain]
The above
SignInAsync
method calls the belowSignInAsync
task, which is contained in theSignInManager
class.If needed, you can access the user's identity details inside a controller action. For instance, by setting a breakpoint inside the
HomeController.Index
action method, you can view theUser.claims
details. By having the user signed-in, you can make authorization decisions. For more information, see Authorization.As a registered user, you can log in to the web app by clicking the Log in link. When a registered user logs in, the
Login
action of theAccountController
is called. Then, the Login action signs in the user using thePasswordSignInAsync
method contained in theLogin
action.[!code-csharpMain]
-
Log off.
Clicking the Log off link calls the
LogOff
action in the account controller.[!code-csharpMain]
The code above shows the
SignInManager.SignOutAsync
method. TheSignOutAsync
method clears the users claims stored in a cookie. -
Configuration.
Identity has some default behaviors that you can override in your application's startup class.
[!code-csharpMain]
-
View the database.
After stopping the application, view the user database from Visual Studio by selecting View -> SQL Server Object Explorer. Then, expand the following within the SQL Server Object Explorer:
-
(localdb)MSSQLLocalDB
-
Databases
-
aspnet5-<the name of your application>
-
Tables
Next, right-click the dbo.AspNetUsers table and select View Data to see the properties of the user you created.
-
Identity Components
The primary reference assembly for the identity system is Microsoft.AspNetCore.Identity
. This package contains the core set of interfaces for ASP.NET Core Identity.
These dependencies are needed to use the identity system in ASP.NET Core applications:
-
EntityFramework.SqlServer
- Entity Framework is Microsoft's recommended data access technology for relational databases. -
Microsoft.AspNetCore.Authentication.Cookies
- Middleware that enables an application to use cookie based authentication, similar to ASP.NET's Forms Authentication. -
Microsoft.AspNetCore.Cryptography.KeyDerivation
- Utilities for key derivation. -
Microsoft.AspNetCore.Hosting.Abstractions
- Hosting abstractions.
Migrating to ASP.NET Core Identity
For additional information and guidance on migrating your existing identity store see Migrating Authentication and Identity