我在使用用户和角色为数据库播种时遇到了问题。
创建了用户和角色(我可以在抛出错误后在数据库中看到它们)。
但是,当我尝试检查用户是否在角色中时,我得到一个例外。
我的代码是:
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 = "marktest@gmail.com" };
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.
在抛出异常后检查时,用户和角色都在数据库中:
任何人都可以看到我做错了吗?
感谢您的帮助,
标记
答案 0 :(得分:26)
我找到了解决方案,以防其他人遇到此问题。
“IsInRole”期待User.Id - 而不是UserName字符串 - 所以我改为:
if (!userManager.IsInRole(user.Id, "Admin"))
{
userManager.AddToRole(user.Id, "Admin");
}
因此工作代码变为:
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);
// Create Role
if (!roleManager.RoleExists("Admin"))
{
roleManager.Create(new IdentityRole("Admin"));
}
if(!userscontext.Users.Any(x=> x.UserName=="marktest"))
{
// Create User
var user = new ApplicationUser { UserName = "marktest", Email = "marktest@gmail.com" };
userManager.Create(user, "Pa$$W0rD!");
// Add User To Role
if (!userManager.IsInRole(user.Id, "Admin"))
{
userManager.AddToRole(user.Id, "Admin");
}
}
我希望有所帮助,
标记
答案 1 :(得分:5)
生活中最简单的事情;
bool isAdmin= User.IsInRole("admin")
答案 2 :(得分:0)
要添加到上述Mark的帖子中,其在.NET Core 3.1中的身份几乎与异步方法IsInRoleAsync唯一相同,您必须传递IdentityUser类型对象:
var userInRole = await _userManager.IsInRoleAsync(user, role);
然后,您可以在以后应用您的逻辑(在我的情况下,我正在做两件事,首先检查角色实际存在,然后检查用户是否尚未分配给该角色)。