【问题标题】:SimpleMembership with SQL Server Compact (SDF) - code first with existing DB使用 SQL Server Compact (SDF) 的 SimpleMembership - 先使用现有数据库编写代码
【发布时间】:2012-11-12 12:40:22
【问题描述】:

可能我遗漏了一些明显的东西,但我无法使基于 SDF 的 ASP.NET MVC 4 Web 应用程序与新的简单成员资格一起工作。我详细说明了我的步骤,因此可以作为其他新手的参考。

首先,我发现这个对新会员系统非常有用的介绍:http://weblogs.asp.net/jgalloway/archive/2012/08/29/simplemembership-membership-providers-universal-providers-and-the-new-asp-net-4-5-web-forms-and-asp-net-mvc-4-templates.aspx。我在现有数据库(SDF 是成熟的现有 SQL Server 数据库的临时占位符)中的代码优先步骤如下:

  1. 我用 VS 2012 创建了一个新的互联网应用程序。
  2. 我向 App_Data (Accounts.sdf) 添加了一个新的 SDF 文件,并在那里为用户和角色创建了我的表。
  3. 我向web.config添加了一个新的连接字符串:
<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,它托管在中间数据层中;在这里,我粘贴了我对模板代码所做的一些相关更改:
...
    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 应用程序引用了 WebMatrix.DataWebMatrix.WebData(均为版本 2),它们已由 VS 模板设置。 那我怎么能让这个工作呢?

【问题讨论】:

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


    【解决方案1】:

    在我当前使用 mssql 的 mvc 4 项目中, 这是一个简单的我,所以我只想要非常简单的会员资格提供者 我禁用了 初始化SimpleMembershipAttribute

    [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
    

    【讨论】:

      【解决方案2】:

      不能说这是显而易见的,但它确实有效。

      为了让 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>
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2010-12-12
        • 1970-01-01
        相关资源
        最近更新 更多