如何在AccountController中使用来自其他控制器的“db”变量

本文关键字:控制器 其他 db 变量 AccountController | 更新日期: 2023-09-27 17:59:22

我需要在应用程序中使用Identity。我不知道如何更改User表。因此,我决定为图像创建一个额外的模型阿凡达

public class Avatar
    {
        [Required]
        [DataType(DataType.MultilineText)]
        public string ImagePath { get; set; }
        [Required]
        public string UserId { get; set; } 
        [Required]
        public int AvatarId { get; set; }
    }

AccountController注册操作中,我想为所有用户添加默认化身:

// POST: /Account/Register
        [HttpPost]
        [AllowAnonymous]
        [ValidateAntiForgeryToken]
        public async Task<ActionResult> Register(RegisterViewModel model)
        {
            if (ModelState.IsValid)
            {
                var user = new ApplicationUser { UserName = model.Email, Email = model.Email };
                var result = await UserManager.CreateAsync(user, model.Password);
                if (result.Succeeded)
                {
                    await SignInManager.SignInAsync(user, isPersistent:false, rememberBrowser:false);
                    Avatar defaultAvatar = new Avatar { UserId = User.Identity.GetUserId(), ImagePath = "default.png"};
                    db.Avatars.Add(defaultAvatar);
                    db.SaveChanges();
                    return RedirectToAction("Index", "Home");
                }
                AddErrors(result);
            }
            return View(model);
        }

但我有一个错误:当前上下文中不存在名称"db"。我选择了正确的方式来实现我的想法?或者有更简单的方法吗?

如何在AccountController中使用来自其他控制器的“db”变量

通过模板生成的某些控制器会获得private YourDbContext db = new YourDbContext();成员。这允许您以任何操作方法访问数据库。

如果您也希望在AccountController中添加该声明,那么也需要在其中添加该声明。

或者将其封装在using块中:

using (var db = new YourDbContext())
{
    db.Avatars.Add(defaultAvatar);
    db.SaveChanges();
}

您必须在控制器构造函数中实例化DbContext。

public class YourController : Controller
{
    private readonly ApplicationDbContext _db;
    public YourController()
    {
        _db = new ApplicationDbContext;
    }
    //Optional: Poor man's dependency injection for unit test
    //Also I highly recommend to have a look at IOC containers.
    public YourController(ApplicationDbContext db)
    {
        _db = db;
    }
}