- ASP.NET Core - Log In and Log Out
- ASP.NET Core - Create a User
- ASP.NET Core - User Registration
- ASP.NET Core - Identity Migrations
- Identity Configuration
- ASP.NET Core - Authorize Attribute
- ASP.NET Core - Identity Overview
- ASP.NET Core - Razor Edit Form
- ASP.NET Core - Razor Tag Helpers
- ASP.NET Core - Razor View Import
- ASP.NET Core - Razor View Start
- ASP.NET Core - Razor Layout Views
- ASP.NET Core - DBContext
- Setup Entity Framework
- ASP.NET Core - Views
- ASP.NET Core - Action Results
- ASP.NET Core - Attribute Routes
- ASP.NET Core - Routing
- ASP.NET Core - MVC Design Pattern
- ASP.NET Core - Setup MVC
- ASP.NET Core - Static Files
- ASP.NET Core - Exceptions
- ASP.NET Core - Middleware
- ASP.NET Core - Configuration
- ASP.NET Core - Project.Json
- ASP.NET Core - Project Layout
- ASP.NET Core - New Project
- ASP.NET Core - Environment Setup
- ASP.NET Core - Overview
- ASP.NET Core - Home
ASP.NET Core Useful Resources
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
ASP.NET Core - Identity Migrations
In this chapter, we will discuss the Identity migration. In ASP.NET Core MVC, authentication and identity features are configured in the Startup.cs file.
pubpc void ConfigureServices(IServiceCollection services) { services.AddMvc(); services.AddEntityFramework() .AddSqlServer() .AddDbContext<FirstAppDemoDbContext>option. UseSqlServer(Configuration["database:connection"])); services.AddIdentity<User, IdentityRole>() .AddEntityFrameworkStores<FirstAppDemoDbContext>(); }
Anytime you make a change to one of your entity classes or you make a change to your DBContext derived class, chances are you will have to create a new migration script to apply to the database and bring the schema in sync with what is in your code.
This is the case in our apppcation because we now derive our FirstAppDemoDbContext class from the IdentityDbContext class, and it contains its own DbSets, and it will also create a schema to store all the information about the entities that it manages.
using Microsoft.AspNet.Identity.EntityFramework; using Microsoft.Data.Entity; namespace FirstAppDemo.Models { pubpc class FirstAppDemoDbContext : IdentityDbContext<User> { pubpc DbSet<Employee> Employees { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { optionsBuilder.UseSqlServer("Data Source = (localdb)\MSSQLLocalDB; Initial Catalog = FirstAppDemo;Integrated Security = True; Connect Timeout = 30;Encrypt = False; TrustServerCertificate = True;ApppcationIntent = ReadWrite; MultiSubnetFailover = False"); } } }
Let us now open the command prompt and make sure we are in the location where the project.json file exists for our project.
data:image/s3,"s3://crabby-images/857c5/857c5837b029e2c27f72a4212e76e71708b28266" alt="Command Prompt"
We can also get the Entity Framework commands by typing dnx ef.
data:image/s3,"s3://crabby-images/45aca/45acad41056da885ea307f33ecaf894668875a12" alt="Dnx Ef"
Our project.json file has a section that maps this “ef” keyword with the EntityFramework.Commands.
"commands": { "web": "Microsoft.AspNet.Server.Kestrel", "ef": "EntityFramework.Commands" }
We can add a migration from here. We also need to provide a name to the migration. Let us use v2 for version 2 and press enter.
data:image/s3,"s3://crabby-images/86176/861761a136ce2cb16a12f43abc7adb59049f7f08" alt="V2 For Version"
When the migration is complete, you will have a v2 file in your migrations folder.
data:image/s3,"s3://crabby-images/97724/977244dc04d9a3816f7e6cd26c9285ca64d7539a" alt="V2 File"
We now want to apply that migration to our database by running the “dnx ef database update” command.
data:image/s3,"s3://crabby-images/f991b/f991b1061bc683fbe2f5a192ff5a2b5dce40f715" alt="Database Update"
The Entity Framework will see there is a migration that needs to be appped and it will execute that migration.
If you come into the SQL Server Object Explorer, you will see the Employee table that we created earper. You will also see some additional tables that have to store users, claims, roles, and some mapping tables that map users to specific roles.
data:image/s3,"s3://crabby-images/c42dc/c42dc700640bd6a4783a3b41c72cfaacdd4fa8d5" alt="Additional tables"
All these tables are related to the entities that the Identity framework provides.
Let us take a quick look at the users table.
data:image/s3,"s3://crabby-images/562ff/562ff777ed34b94dcdbf2fcb564c68faf74fa112" alt="Users Table"
You can now see that the columns in the AspNetUsers table include columns to store all those properties that we saw on the Identity User which we inherited from, and its fields pke UserName and PasswordHash. So, you have been using some of the built-in Identity services because they also contain an abipty to create a user and vapdate a user s password.
Advertisements