У меня возникла проблема с посещением моей базы данных пользователями и ролями.Проверка наличия пользователя в роли asp.net mvc Удостоверение
Созданы оба пользователя и роль (я могу видеть их в базе данных после того, как была выбрана ошибка).
Однако, когда я пытаюсь проверить, является ли пользователь в роли, я получаю исключение.
Мой код:
public class tbInitializer<T> : DropCreateDatabaseAlways<tbContext>
{
protected override void Seed(tbContext context)
{
ApplicationDbContext userscontext = new ApplicationDbContext();
var userStore = new UserStore<ApplicationUser>(userscontext);
var userManager = new UserManager<ApplicationUser>(userStore);
var roleStore = new RoleStore<IdentityRole>(userscontext);
var roleManager = new RoleManager<IdentityRole>(roleStore);
if(!userscontext.Users.Any(x=> x.UserName=="marktest"))
{
var user = new ApplicationUser { UserName = "marktest", Email = "[email protected]" };
userManager.Create(user, "Pa$$W0rD!");
}
if (!roleManager.RoleExists("Admin"))
{
roleManager.Create(new IdentityRole("Admin"));
}
if(!userManager.IsInRole("marktest","Admin"))
{
userManager.AddToRole("marktest","Admin");
}
Однако, на линии:
if(!userManager.IsInRole("marktest","Admin"))
Исключение брошено с ошибкой: UserId not found.
пользователем и роль являются как в базе данных, когда я проверяю после исключения:
Может кто-нибудь увидеть, что я делаю неправильно?
Спасибо за любую помощь,
Марк
Вы пробовали 'SaveChanges()' before' if (! UserManager.IsInRole ("marktest", "Admin")) '? – Bruniasty
Привет - да, я добавил 'context.SaveChanges();' - как раз перед этой строкой, но все равно выбрасывает исключение с той же ошибкой. Спасибо, Mark – Mark
Является ли пользователь «marktest», сохраненный в базе данных? – Bruniasty