我目前正在使用带有CreateAsync(newRoleName)方法的RoleManager将角色添加到我们的数据库中 - 这可以正常工作。但是当我尝试查询该角色时,它总是返回它不存在(即使我可以在数据库中看到它)。
任何人都可以提供一些有关我无法使用该角色的见解吗?
var roleExists = roleManager.RoleExistsAsync(role);
if (!roleExists.Result)
{
var newRole = new IdentityRole(role)
{
Name = role,
NormalizedName = role.ToUpper(),
};
var roleCreated = roleManager.CreateAsync(newRole);
Thread.Sleep(500); // Used to get result back first.
var roleExistsYet = roleManager.RoleExistsAsync(role);
if (!roleExists.Result)
{
// ALWAYS Returns [False]
}
}
当我们使用UserManager创建新用户时出现了初始问题,以下方法会导致错误
var roleAddResult = userManager.AddToRoleAsync(newUser, "TestRole123");
异常错误:角色[TESTROLE123]不存在。
注意:我可以看到角色' TestRole123'的条目。 (或任何其他角色)表dbo.AspNetRoles中的数据库中。
感谢任何见解或帮助。
环境:Visual Studio 2017,Asp.NET Core,C#
答案 0 :(得分:0)
我不知道你是如何宣布你的角色管理员的,但是以下代码对我有用。它在startup.cs中配置,如果尚未创建角色,则自动创建超级用户。也许这可以帮到你?
var roleManager = new RoleManager<IdentityRole>(new RoleStore<IdentityRole>(context));
var userManager = new UserManager<ApplicationUser>(new UserStore<ApplicationUser>(context));
if (!roleManager.RoleExists("SuperUser"))
{
roleManager.Create(new IdentityRole("SuperUser"));
//superuser
var user = new ApplicationUser
{
UserName = " Name",
Email = "Email",
Firstname = "Firstname",
Lastname = "Lastname"
};
var pass = "AwesomePasswordOverHere";
var chkUser = await userManager.CreateAsync(user, pass);
//make superuser
if (chkUser.Succeeded)
{
await userManager.AddToRoleAsync(user.Id, "SuperUser");
}
}
答案 1 :(得分:0)
我看到的一个问题 - 您需要在await
方法前使用关键字*Async()
:
var roleExists = await roleManager.RoleExistsAsync(role);
和
var roleCreated = await roleManager.CreateAsync(newRole);
等。这样就无需执行Thread.Sleep(500);
- 很可能问题在于此行。
如果您不能执行异步方法,请使用方法的非异步版本:
var roleCreated = roleManager.Create(newRole);