使用SQL Server Compact(SDF)的SimpleMembership - 首先使用现有数据库进行编码

时间:2012-11-12 12:40:23

标签: asp.net-mvc sql-server-ce asp.net-membership simplemembership

可能我错过了一些显而易见的东西,但我无法使用新的简单会员资格获得基于SDF的ASP.NET MVC 4 Web应用程序。我详细说明了我的步骤,因此这可以作为其他新手的参考。

首先,我发现这对新会员系统非常有用:[{3}}。我在使用现有数据库的代码优先级中的步骤(SDF是完整的现有SQL Server数据库的临时占位符)如下:

  1. 我使用VS 2012创建了一个新的互联网应用程序。
  2. 我向App_Data(Accounts.sdf)添加了一个新的SDF文件,并在那里为用户和角色创建了表格。
  3. 我向web.config添加了一个新的连接字符串:
  4. <connectionStrings>
          <clear/>
          <add name="AccountsContext" connectionString="Data Source=|DataDirectory|\Accounts.sdf;Persist Security Info=False" providerName="System.Data.SqlServerCe.4.0" />
        </connectionStrings>
    
    1. 我将InitializeSimpleMembershipAttribute.cs文件更改为使用我自己的datacontext,该文件位于中间数据层中;在这里,我将对模板代码所做的一些相关更改粘贴到其中:
    2. ...
          public SimpleMembershipInitializer()
          {
              Database.SetInitializer(null);
              try
              {
                  using (AccountsContext context = new AccountsContext())
                  {
                      if (!context.Database.Exists())
                      {
                          ((IObjectContextAdapter)context).ObjectContext.CreateDatabase();
                      }
                  }
                  WebSecurity.InitializeDatabaseConnection("AccountsContext", "User", "Id", "Name", autoCreateTables: true);
                  // seed data here...
              }
          ...
      

      这是数据上下文(注意默认ctor中的连接字符串名称):

      public sealed class AccountsContext : DbContext
      {
          public DbSet<User> Users { get; set; }
          public DbSet<Role> Roles { get; set; }
      
          public AccountsContext() : base("Name=AccountsContext")
          {
              Database.Initialize(false);
          }
      
          public AccountsContext(string nameOrConnectionString) : base(nameOrConnectionString)
          {
              Database.Initialize(false);
          }
      
          public AccountsContext(DbConnection connection, bool contextOwnsConnection) : 
              base(connection, contextOwnsConnection)
          {
              Database.Initialize(false);
          }
      
          protected override void OnModelCreating(DbModelBuilder modelBuilder)
          {
              base.OnModelCreating(modelBuilder);
      
              modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
      
              // user
              modelBuilder.Entity<User>().Property(u => u.Id)
                  .HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
      
              // role
              modelBuilder.Entity<Role>().Property(r => r.Id)
                  .HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
              modelBuilder.Entity<Role>().ToTable("webpages_Roles");
              modelBuilder.Entity<Role>().Property(r => r.Id).HasColumnName("RoleId");
              modelBuilder.Entity<Role>().Property(r => r.Name).HasColumnName("RoleName");
      
              // user-role
              modelBuilder.Entity<User>()
                  .HasMany(u => u.Roles)
                  .WithMany(r => r.Users)
                  .Map(m =>
                  {
                      m.MapLeftKey("UserId");
                      m.MapRightKey("RoleId");
                      m.ToTable("webpages_UsersInRoles");
                  });
          }
      }
      

      现在,当我运行Web应用程序时,我立即得到一个异常,告诉我找不到LocalSqlServer连接名称。这属于machine.config,我可以在这里找到这些条目:

      ...
      <membership>
      <providers>
        <add name="AspNetSqlMembershipProvider" type="System.Web.Security.SqlMembershipProvider, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" connectionStringName="LocalSqlServer" .../>
        <add name="MySQLMembershipProvider" type="MySql.Web.Security.MySQLMembershipProvider, MySql.Web, Version=6.5.4.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" connectionStringName="LocalMySqlServer" ... autogenerateschema="true"/>
      </providers>
      ...
      

      因此,我尝试通过将这些行添加到web.config

      来覆盖这些条目
      <roleManager enabled="true" defaultProvider="SimpleRoleProvider">
        <providers>
          <clear/>
          <add name="SimpleRoleProvider" type="WebMatrix.WebData.SimpleRoleProvider, WebMatrix.WebData"/>
        </providers>
      </roleManager>
      <membership defaultProvider="SimpleRoleProvider">
        <providers>
          <clear/>
          <add name="SimpleMembershipProvider" type="WebMatrix.WebData.SimpleMembershipProvider, WebMatrix.WebData"/>        
        </providers>
      </membership>
      

      如果我现在运行应用程序,我会得到这样的例外:

      System.Configuration.ConfigurationErrorsException
      Message=Default Membership Provider could not be found.
      Source=System.Web
      BareMessage=Default Membership Provider could not be found.
      

      然而,Web应用程序引用了已经由VS模板设置的WebMatrix.DataWebMatrix.WebData(两个版本2)。 那么我怎么能让这个工作呢?

2 个答案:

答案 0 :(得分:2)

在我目前使用mssql的mvc 4项目中, 它是一个简单的我所以我只想要非常简单的记忆提供者 我禁用了 InitializeSimpleMembershipAttribute

通过

[Authorize]
//[InitializeSimpleMembership]
public partial class AccountController : Controller

并将此代码添加到Application_Start下的global.asax 所以你不再需要SimpleMembershipInitializer

WebSecurity.InitializeDatabaseConnection(
             connectionStringName: "DefaultConnection",
             userTableName: "UserProfile",
             userIdColumn: "UserID",
             userNameColumn: "UserName",
             autoCreateTables: true);

在我的sql数据库中,应用程序创建了一些表格,其中Roles和UserInRoles刚刚添加了我需要的角色,如管理员,客户等... 您可以对数据库执行相同操作,也可以构建一些界面来管理角色和记忆。 并通过添加此代码来限制对某些控制器或操作的访问

[Authorize(Roles = "Admin")]
public class MessagesController : Controller

答案 1 :(得分:1)

不能说这很明显,但确实有效。

为了让SimpleMembeship与SQL Compact一起使用,您需要做的第一件事是使用Nuget“EntityFramework.SqlServerCompact”和“Microsoft ASP.NET Universal Providers Core Library”添加

您的连接字符串的名称是“AccountsContext”,您的模型应该具有相同的名称:

   public class UsersContext : DbContext
    {
        public UsersContext()
            : base("AccountsContext")
        {
        }

        public DbSet<UserProfile> UserProfiles { get; set; }
        public DbSet<webpages_Membership> Membership { get; set; }
    }

然后,你的部分不应该有任何SQL相关,因为这是为了ASP安全,而不是新的SimpleMembership;这是我的样子:

<membership defaultProvider="simple">
      <providers>
        <clear />
        <add name="simple" type="WebMatrix.WebData.SimpleMembershipProvider, WebMatrix.WebData" />
      </providers>
    </membership>