ASP.net MVC + ASP.net Identity Seeding角色和用户

时间:2013-12-09 12:24:52

标签: asp.net asp.net-mvc asp.net-mvc-5 asp.net-identity

在迁移配置类中,有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和Administrator角色已连接。

但是当我将属性[Authorize(Roles = "Administrator")]放在控制器上方时,我已被重定向到登录页面,好像我的用户不在那个角色中,所以我在控制器中添加了一行:

var x = _userManager.IsInRole(_userManager.FindByName("someUserName").Id, "Administrator");

x是假的。为什么会这样?我该如何解决?如果这不是种子数据库的正确方法,那是什么?

2 个答案:

答案 0 :(得分:7)

尝试种子方法

 context.Configuration.LazyLoadingEnabled = true;

这是我对禁用延迟加载时发生的事情的猜测,当UserManager或UserStore访问它时,IdentityUser / ApplicationUser对象的Roles属性为null或为空,因为该集合不是手动加载。然后代码继续进行,就像没有为用户分配任何角色,实际上这个集合从未加载过。

答案 1 :(得分:0)

尝试

context.SaveChanges();
在种子方法结束时