InitializeIdentityForEF冻结并且不会创建默认管理员帐户

时间:2015-05-07 19:51:03

标签: asp.net asp.net-mvc entity-framework asp.net-identity

当我第一次开始这个项目时,我没有错误。

现在,当我运行项目并创建数据库时,它会继续加载和加载。如果我再次停止并再次运行,一切正常,但我的管理员帐户未创建。

我使用的是Identity 2.0。

以下是代码:

 public static void InitializeIdentityForEF(ApplicationDbContext db) {
        var userManager = HttpContext.Current.GetOwinContext().GetUserManager<ApplicationUserManager>();
        var roleManager = HttpContext.Current.GetOwinContext().Get<ApplicationRoleManager>();
        const string name = "admin@mundogato.org";
        const string password = "Admin@1234";
        const string roleName = "Admin";

        //Create Role Admin if it does not exist
        var role = roleManager.FindByName(roleName);
        if (role == null) {
            role = new ApplicationRole(roleName);
            var roleresult = roleManager.Create(role);
        }

        var user = userManager.FindByName(name);
        if (user == null) {
            user = new ApplicationUser { UserName = name, Email = name };
            var result = userManager.Create(user, password);
            result = userManager.SetLockoutEnabled(user.Id, false);
        }

        // Add user admin to Role Admin if not already added
        var rolesForUser = userManager.GetRoles(user.Id);
        if (!rolesForUser.Contains(role.Name)) {
            var result = userManager.AddToRole(user.Id, role.Name);
        }
    }

1 个答案:

答案 0 :(得分:2)

在那个时候OWIN还没准备就绪的问题。假设ApplicationDbContext派生自身份上下文:

,请为管理者尝试此代码
var roleManager = new RoleManager<IdentityRole>(new RoleStore<IdentityRole>(db));
var userManager = new UserManager<ApplicationUser>(new UserStore<ApplicationUser>(db));

请参阅Understanding MVC-5 Identity