如何在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"。我选择了正确的方式来实现我的想法?或者有更简单的方法吗?
通过模板生成的某些控制器会获得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;
}
}