任务50:Identity MVC:DbContextSeed初始化

任务50:Identity MVC:DbContextSeed初始化

 

首先添加seed数据库

每次应用程序启动,监测一下,是不是第一次启动。若是是第一次执行,咱们须要在数据库内添加一个记录async

好比说咱们的用户帐号,咱们在第一次进来的时候,咱们须要有一个管理员ide

 

在Data文件夹下新建:测试

ApplicationDbContextSeed.csui

 

 

 

 

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Identity;
using MvcCookieAuthSample.Models;
using Microsoft.Extensions.DependencyInjection;

namespace MvcCookieAuthSample.Data
{
    public class ApplicationDbContextSeed
    {
        private UserManager<ApplicationUser> _userManager;
        public async Task SeedAsync(ApplicationDbContext context,IServiceProvider services)
        {
            if (context.Users.Any())
            {
                _userManager = services.GetRequiredService<UserManager<ApplicationUser>>();
                var defaultUser = new ApplicationUser
                {
                    UserName = "Administrator",
                    Email = "haogeili@163..com",
                    NormalizedEmail="admin"
                };

                var result=await _userManager.CreateAsync(defaultUser, "Password$123");
                if (!result.Succeeded)
                {
                    throw new Exception("初始默认用户失败!");
                }
            }
        }
    }
}
ApplicationDbContextSeed

 

 

调用Seed方法

WebHostMigrationExtensions.csspa

 

这里扩展的方法,咱们要扩展的是IWebHostcode

 

 

 

 

这里咱们要把依赖注入引入进来orm

 

 

 

 

 

 

包装器咱们在哪里使用呢?Program.cs程序启动文件里面blog

 

 

这样咱们的初始化就完成了。it

 

          .MigrationDbContext<ApplicationDbContext>((context,services)=> {
                    new ApplicationDbContextSeed().SeedAsync(context, services)
                    .Wait();
                })

 

 

运行测试

 

先把咱们本地的数据库删掉。而后再运行咱们的程序

 

 

更正代码

 

看到咱们执行成功的输出信息

 

默认已经初始化的 用户信息

 

 

 

纠正代码错误:

 

从新运行并新建数据库

 

 

登录成功。!!!!!

相关文章
相关标签/搜索