在迁移配置类中,有Seed方法,其代码如下:
protected override void Seed(DatabaseContext context)
{
var roleManager = new RoleManager<IdentityRole>(new RoleStore<IdentityRole>(context));
var userManager = new UserManager<User>(new UserStore<User>(context));
if (!roleManager.RoleExists("Administrator"))
{
roleManager.Create(new IdentityRole("Administrator"));
}
var user = new User {UserName = "someUserName"};
if (userManager.FindByName("someUserName") == null)
{
var result = userManager.Create(user, "password");
if (result.Succeeded)
{
userManager.AddToRole(user.Id, "Administrator");
}
}
}
然后在 PM 控制台中,我运行了 update-database 命令,成功地种植了数据库,在 AspNetUserRoles 表格中,我可以看到用户 someUserName 和管理员角色已连接。
但是,当我在控制器上方添加属性 [Authorize(Roles = "Administrator")]
后,我被重定向到登录页面,就好像我的用户不属于该角色一样,所以我在控制器中添加了以下代码:
var x = _userManager.IsInRole(_userManager.FindByName("someUserName").Id, "Administrator");
x是假的。为什么会这样?我该如何解决?如果这不是种子数据库的正确方法,那么应该怎么做?