5

我正在关注使用 Identity 的文档并尝试注册新用户(执行注册操作),但它失败并出现以下错误:

InvalidOperationException:无法为“ApplicationUser”创建 DbSet,因为此类型未包含在上下文模型中。

启动:

services.AddIdentity<ApplicationUser, IdentityRole>(options =>
{
    //password options
    options.Password.RequireDigit = false;
    // ...
})

我正在使用标准的 ApplicationUser:

public class ApplicationUser : IdentityUser
{
}

在 AccountController 中注册操作:

public async Task<IActionResult> Register(RegisterViewModel viewModel)
{
    if (ModelState.IsValid)
    {
        var user = new ApplicationUser { UserName = viewModel.UserName, Email = viewModel.Email };
        var result = await _userManager.CreateAsync(user, viewModel.Password); //<-- Exception happens here
        if (result.Succeeded)
        {
            await _signInManager.SignInAsync(user, isPersistent: false);
            _logger.LogInformation(3, "User created a new account with password.");
            return RedirectToAction(nameof(HomeController.Index), "Home");
        }

        string errorData = "";
        foreach (var error in result.Errors)
        {
            errorData += error.Description + '\n';
        }
        StoreErrorMessage("Failed to create the user!", errorData);
    }

    return View(viewModel);
}

我已经尝试了以下方法:

  • 添加DbSet<ApplicationUser>AplicationContext
  • 我确实通过dotnet ef
4

2 回答 2

12

我发现了问题。我ApplicationContext的继承自DbContext. 我将其更改为IdentityDbContext<ApplicationUser>并且可以正常工作。

于 2016-09-01T03:57:55.890 回答
2

创建继承 IdentityDbContext 的新上下文类。

public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
    public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
        : base(options)
    {
    }

    protected override void OnModelCreating(ModelBuilder builder)
    {
        base.OnModelCreating(builder);
        // Customize the ASP.NET Identity model and override the defaults if needed.
        // For example, you can rename the ASP.NET Identity table names and more.
        // Add your customizations after calling base.OnModelCreating(builder);
    }
}

并在 startup.cs 文件中添加以下代码

services.AddDbContext<ApplicationDbContext>(options =>
            options.UseSqlServer(connection));

这将帮助您使用数据库优先方法。

于 2017-11-09T18:02:52.373 回答