[英]Entity Framework Enable-Migrations –EnableAutomaticMigrations?
我正在使用Authnetication表單,在該表單中,我使用了自己的實體框架,並且還使用了DataContext為用戶提供角色。 我已經將DataCOntectInitializer進行了硬編碼,如下所示
公共類DataContextInitializer:CreateDatabaseIfNotExists {保護重寫void Seed(DataContext context){角色role1 =新角色{RoleName =“ Admin”}; 角色role2 =新角色{RoleName =“ User”};
User user1 = new User { Username = "admin", EmailId = "admin@ymail.com", FirstName = "Admin", Password = "123456", IsActive = true, DateCreated = DateTime.UtcNow, Roles = new List<Roles>() };
User user2 = new User { Username = "user1", EmailId = "user1@ymail.com", FirstName = "User1", Password = "123456", IsActive = true, DateCreated = DateTime.UtcNow, Roles = new List<Roles>() };
user1.Roles.Add(role1);
user2.Roles.Add(role2);
context.Users.Add(user1);
context.Users.Add(user2);
context.SaveChanges();
}
}
我的登錄方法是:
[HttpPost] [AllowAnonymous]
public ActionResult Login(LoginViewModel model, string returnUrl=" ")
{
if (ModelState.IsValid)
{
var user1 = Context.Users.Where(u => u.Username == model.Username && u.Password == model.Password).FirstOrDefault();
var user = ob.Users.Where(u => u.Username == model.Username && u.Password == model.Password).FirstOrDefault();
if (user != null)
{
var roles = user.Roles.Select(m => m.RoleName).ToArray();
CustomPrincipalSerializeModel serializeModel = new CustomPrincipalSerializeModel();
serializeModel.UserId = user.UserId;
serializeModel.FirstName = user.FirstName;
serializeModel.LastName = user.LastName;
serializeModel.roles = roles;
string userData = JsonConvert.SerializeObject(serializeModel);
FormsAuthenticationTicket authTicket = new FormsAuthenticationTicket(1, user1.EmailId, DateTime.Now, DateTime.Now.AddMinutes(15), false, userData);
string encTicket = FormsAuthentication.Encrypt(authTicket);
HttpCookie faCookie = new HttpCookie(FormsAuthentication.FormsCookieName, encTicket);
Response.Cookies.Add(faCookie);
if ( roles.Contains("Admin"))
{
return RedirectToAction("Index", "Admin");
}
else if (roles.Contains("User"))
{
return RedirectToAction("Index", "User");
}
else
{
return RedirectToAction("Index", "Home");
}
}
}
// If we got this far, something failed, redisplay form
ModelState.AddModelError("", "The user name or password provided is incorrect.");
return View(model);
}
我的模型類如下:
公共類用戶{
public int UserId { get; set; }
[Required]
public String Username { get; set; }
[Required]
public String EmailId { get; set; }
[Required]
public String Password { get; set; }
public String FirstName { get; set; }
public String LastName { get; set; }
public Boolean IsActive { get; set; }
public DateTime DateCreated { get; set; }
public virtual ICollection<Roles> Roles { get; set; }
}
和
公共類角色{
[Key]
public int RoleId { get; set; }
[Required]
public string RoleName { get; set; }
public string Description { get; set; }
public virtual ICollection<User> Users { get; set; }
}
問題就像當我嘗試使用我的用戶名和密碼登錄時,需要從DatContext類檢查角色。
但是那時我的角色還沒有來自DataContext類,而是提供了ArgumentNullException。
參見本文@ Oliboy50回答的文章( 實體框架6-處理嵌套對象的加載 ),這可能會有所幫助,您需要包括虛擬角色,以便加載集合
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.