0

我是ASP.NET初学者,我试图在ASP.NET-MVC项目中使用Identity框架构建用户系统。Usermanager与模型继承自应用程序用户

我想有“Admin”用户实体从基础机构“applicationUser”这是默认在我的模型创建(我小的改动)继承:

public class ApplicationUser : IdentityUser 
{ 
    [Required] 
    [StringLength(50)] 
    [Display(Name = "Last Name")] 
    public string LastName { get; set; } 
    [Required] 
    [StringLength(50, ErrorMessage = "First name cannot be longer than 50 characters.")] 
    [Column("FirstName")] 
    [Display(Name = "First Name")] 
    public string FirstMidName { get; set; } 

    [Display(Name = "Full Name")] 
    public string FullName 
    { 
     get 
     { 
      return LastName + ", " + FirstMidName; 
     } 
    } 
} 
public class Admin: ApplicationUser 
{ 
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)] 
    public int AdID; 
} 

我也将从添加其他2继承applicationUser,我想为不同的用户分别存储不同的信息,以便在他们的数据库文件中存储不同的信息,并让他们全部登录到我的网站。

在启动时我试图最初使用此代码添加管理员用户(某处取计算器的答案):

 public static async Task CreateRoles(SchoolContext context, IServiceProvider serviceProvider) 
     { 

      var userManager = serviceProvider.GetRequiredService<UserManager<ApplicationUser>>(); 
      var roleManager = serviceProvider.GetRequiredService<RoleManager<IdentityRole>>(); 
      // First, Creating User role as each role in User Manager 
      List<IdentityRole> roles = new List<IdentityRole>(); 

      roles.Add(new IdentityRole { Name = "Student", NormalizedName = "STUDENT" }); 
      roles.Add(new IdentityRole { Name = "ADMIN", NormalizedName = "ADMINISTRATOR" }); 
      roles.Add(new IdentityRole { Name = "Professor", NormalizedName = "PROFESSOR" }); 

      //Then, the machine added Default User as the Admin user role 
      foreach (var role in roles) 
      { 
       var roleExit = await roleManager.RoleExistsAsync(role.Name); 
       if (!roleExit) 
       { 
        context.Roles.Add(role); 
        context.SaveChanges(); 
       } 
      } 

      await CreateUser(context, userManager); 
     } 


     private static async Task CreateUser(SchoolContext context, UserManager<ApplicationUser> userManager) 
     { 
      var adminUser = await userManager.FindByEmailAsync("[email protected]"); 
      if (adminUser != null) 
      { 
       if (!(await userManager.IsInRoleAsync(adminUser, "ADMINISTRATOR"))) 
        await userManager.AddToRoleAsync(adminUser, "ADMINISTRATOR"); 
      } 
      else 
      { 
       var newAdmin = new applicationUser() 
       { 
        UserName = "[email protected]", 
        Email = "[email protected]", 
        LastName = "Admin", 
        FirstMidName = "Admin", 

       }; 
       var result = await userManager.CreateAsync(newAdmin, "password123;"); 
       if (!result.Succeeded) 
       { 
        var exceptionText = result.Errors.Aggregate("User Creation Failed 
        - Identity Exception. Errors were: \n\r\n\r", 
        (current, error) => current + (" - " + error + "\n\r")); 
        throw new Exception(exceptionText); 
       } 
       await userManager.AddToRoleAsync(newAdmin, "ADMINISTRATOR"); 
      } 
     } 

但是,当我尝试这样做,我收到一个异常: “无法插入值'NULL'列'Discriminator',表'aspnet-University;列不允许空值INSERT失败。 该语句已被终止。

如果我尝试更改“new Admin”而不是“new applicationUser”的变量Admin类型,我收到另一个异常: 找不到实体类型'Admin'。确保实体类型已被添加到模型中。

我知道这个问题是关于身份框架的基础知识;我还没有很好地理解他们;我刚开始明白这是原理,我不知道如何处理我的问题。

我想我需要创建新的UserManager,它将能够操纵从基本applicationUser模型继承的实例。如果您向我推荐有关此主题的相关资源并帮助我解决问题,我将很高兴。

回答

0

如果有人会有这个问题 - 我决定不使用ApplicationUser的继承,因为它显然是错误的方法,而是继承IdentityUser类中的所有自定义用户模型。为了使这项工作我已经添加到启动配置服务这一行:

services.AddIdentity <IdentityUser, IdentityRole>() 
       .AddEntityFrameworkStores<YourContext>() 
       .AddDefaultTokenProviders(); 

我的用户模型声明如下:

public class Admin : IdentityUser 
    { 
    } 

而且在上下文中的文件我有这样的:

protected override void OnModelCreating(ModelBuilder modelBuilder) 
     { 
      modelBuilder.Entity<IdentityUser>(i => { 
       i.ToTable("Users"); 
       i.HasKey(x => x.Id); 
      }); 
      modelBuilder.Entity<IdentityRole<>(i => { 
       i.ToTable("Role"); 
       i.HasKey(x => x.Id); 
      }); 
} 

使用此代码,我可以使用Identity的UserManager和RoleManager,而无需其他更改。