繁体   English   中英

在asp.net核心的dbcontext中播种用户和角色:循环依赖问题

[英]Seeding users and roles in dbcontext in asp.net core: Circular dependency problem

我将dbcontext文件中的UserManagerRoleManager注入, RoleManager在首次创建数据库时使用它们来添加一些用户和角色。 当我运行update-database命令时,出现以下错误:

检测到类型为“ App.Models.AppDbContext”的服务的循环依赖关系。 App.Models.AppDbContext-> Microsoft.AspNetCore.Identity.UserManager-> Microsoft.AspNetCore.Identity.IUserStore

以下是dbcontext

public class AppDbContext : IdentityDbContext
{
    private readonly UserManager<ApplicationUser> _userManager;
    private readonly RoleManager<IdentityRole> _roleManager;

    public AppDbContext(
        DbContextOptions<SynergyDbContext> options,
        UserManager<ApplicationUser> userManager,
        RoleManager<IdentityRole> roleManager
        ) : base(options) {

        _userManager = userManager;
        _roleManager = roleManager;
    }

    modelBuilder.Entity<IdentityRole>().HasData(new IdentityRole { Name = "Admin", NormalizedName = "Admin".ToUpper() });

     ApplicationUser user = new ApplicationUser
     {
         //implementation details
     };

     IdentityResult result = _userManager.CreateAsync(user, "password").Result;
     if (result.Succeeded) _userManager.AddToRoleAsync(user, "Admin").Wait();

     base.OnModelCreating(modelBuilder);
 }

有任何想法吗? 我应该使用HasData方法创建用户吗?

您的AppDbContext注入了依赖项UserManager ,注入了依赖项UserStore ,依赖项UserStore注入了依赖项DbContext 因此,您会遇到循环依赖问题。

解决方案是在DbContext之外创建您的用户,因此不要将这些服务注入DbContext

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM