3

MVC アプリケーションにデフォルトのロール (管理者とユーザー) とデフォルトのユーザー (管理者) を作成する必要があります。コードファーストアプローチを使用しています。私は MVC を初めて使用し、移行についてあまり知りません。

次のコードを試しましたが、まだテーブル ( webpages_RolesUserProfile ) は空白です:

 protected override void Seed(Outliner.Models.OutlinerDbContext context)
        {
            //  This method will be called after migrating to the latest version.

            //  You can use the DbSet<T>.AddOrUpdate() helper extension method 
            //  to avoid creating duplicate seed data. E.g.
            //
            //    context.People.AddOrUpdate(
            //      p => p.FullName,
            //      new Person { FullName = "Andrew Peters" },
            //      new Person { FullName = "Brice Lambson" },
            //      new Person { FullName = "Rowan Miller" }
            //    );
            //

            WebSecurity.InitializeDatabaseConnection("DefaultConnection", "UserProfile", "UserId", "UserName", autoCreateTables: true);

            var roles = (SimpleRoleProvider)System.Web.Security.Roles.Provider;
            var membership = (SimpleMembershipProvider)System.Web.Security.Membership.Provider;

            if (!roles.RoleExists("Admin"))
                roles.CreateRole("Admin");

            if (!roles.RoleExists("User"))
                roles.CreateRole("User");

            if (General.IsNull(membership.GetUser("admin", false)))
            {
                WebSecurity.CreateAccount("admin", "password");
            }
        }

私の要件を満たすための正しいアプローチは何ですか?

4

1 に答える 1

4

データベース初期化子を設定しましたか?

たとえば、次のコードをApplication_Start()メソッドに追加します。Global.asax

System.Data.Entity.Database.SetInitializer(new OutlinerDbInitializer());

初期化用のクラスには次の署名があると思います。

public class OutlinerDbInitializer: DropCreateDatabaseIfModelChanges<Outliner.Models.OutlinerDbContext context> {
    ...
}

この例を見てみてください:

http://www.itorian.com/2012/10/entity-frameworks-database-seed-method.html

于 2013-10-24T09:16:18.860 に答える