我现在已经实现了以下解决方案。
正如CodeNotFound在注释中指出的那样,IdentityUser曾经具有一个
Roles属性。.NET
Core中不再是这种情况。GitHub上的此注释/问题似乎是.Net
Core的当前解决方案。我试图用以下代码实现它:
应用用户
public class ApplicationUser : IdentityUser{ public ICollection<ApplicationUserRole> UserRoles { get; set; }}ApplicationUserRole
public class ApplicationUserRole : IdentityUserRole<string>{ public virtual ApplicationUser User { get; set; } public virtual ApplicationRole Role { get; set; }}应用角色
public class ApplicationRole : IdentityRole{ public ICollection<ApplicationUserRole> UserRoles { get; set; }}数据库上下文
public class ApplicationDbContext : IdentityDbContext<ApplicationUser, ApplicationRole, string, IdentityUserClaim<string>, ApplicationUserRole, IdentityUserLogin<string>, IdentityRoleClaim<string>, IdentityUserToken<string>>{ public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options) : base(options) { } protected override void onModelCreating(ModelBuilder builder) { base.onModelCreating(builder); builder.Entity<ApplicationUserRole>(userRole => { userRole.HasKey(ur => new { ur.UserId, ur.RoleId }); userRole.HasOne(ur => ur.Role) .WithMany(r => r.UserRoles) .HasForeignKey(ur => ur.RoleId) .IsRequired(); userRole.HasOne(ur => ur.User) .WithMany(r => r.UserRoles) .HasForeignKey(ur => ur.UserId) .IsRequired(); }); }}启动
services.AddIdentity<ApplicationUser, ApplicationRole>(options => options.Stores.MaxLengthForKeys = 128) .AddEntityframeworkStores<ApplicationDbContext>() .AddDefaultTokenProviders();
最后,请确保在使用它时先加载用户的UserRoles,然后再加载UserRole的Role,如下所示:
this.Users = userManager.Users.Include(u => u.UserRoles).ThenInclude(ur => ur.Role).ToList();
我有一个问题,其中
Role每个属性
UserRole均为null,并通过添加
.ThenInclude(ur => ur.Role)零件来解决。
关于多级紧急加载的Microsoft文档:https :
//docs.microsoft.com/zh-cn/ef/core/querying/related-data#includes-multiple-
levels
ASP Core 2.2更新
IdentityUserRole<Guid>不是字符串的固有特性您可能还需要删除ModelBuilder中的代码才能使迁移正常进行。



