MVC 5 UserManager: 实体类型ApplicationUser不是当前上下文模型的一部分

5

我正在尝试(但失败了)将MVC的实现到我的网站中。 我觉得我的情况相当简单。 我有一个User类(Entity Framework - Database first),其中包含所有用户的信息。 并非来自的每个用户都可以访问网站。 因此,在我的ApplicationUser中,有一个链接指向这个类。 在代码中,它看起来像这样:

public partial class User
{
    public int Id { get; set; }
    public string Firstname { get; set; }
    public string Lastname { get; set; }
    public string Email { get; set; }
}

public class ApplicationUser : IdentityUser
{
    public virtual Entities.User UserInfo { get; set; }

    public ApplicationUser()
    {
        UserInfo = new Entities.User();
    }
}

当在控制器中调用CreateUserAsync方法时,一切都出了问题。以下是我的控制器代码。

public class AccountController : BaseController
{
    public UserManager<ApplicationUser> UserManager { get; private set; }

    public async Task<ActionResult> Register(RegisterViewModel model)
    {
        if (ModelState.IsValid)
        {
            var dbUser = new User 
            { 
                Firstname = model.FirstName, 
                Lastname = model.LastName, 
                Email = model.UserName 
            };
            db.Users.Add(dbUser);
            db.SaveChanges();

            var appUser = new ApplicationUser(model.UserName);
            appUser.UserInfo = dbUser;

            try
            {
                var result = await UserManager.CreateAsync(appUser, model.Password);
            }
            catch (Exception e)
            {
                db.Users.Remove(dbUser);
                db.SaveChanges();
            }
        }
    }
}
CreateUserAsync 方法出现以下错误:当前上下文的模型中不包括实体类型 ApplicationUser。 现在我的问题是:
  1. 我是否按照“mvc”的方式进行操作?我认为这是微不足道的事情,但需要付出大量的努力。
  2. 如果不是,请问有更好的方法可以实现这一点吗?

UserManager是从哪里来的? - Anthony Chu
创建MVC5项目时默认的UserManager。我已经更新了代码。 - Thijs
1个回答

3
问题在于,您尝试将一个已经添加到一个DbContext中的用户添加到由UserManager创建的另一个DbContext中的ApplicationUser中。
相反,您应该将其作为单个操作执行。只需执行以下操作即可:
var dbUser = new User 
{ 
    Firstname = model.FirstName, 
    Lastname = model.LastName, 
    Email = model.UserName 
};
var appUser = new ApplicationUser(model.UserName);
appUser.UserInfo = dbUser;
try
{
   var result = await UserManager.CreateAsync(appUser, model.Password);
}
catch (Exception e)
{
   // show error or whatever
}

我需要在web.config中进行不同的连接,然后这种方法才能起作用。谢谢! - Thijs

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接