asp.net-mvc - SimpleMembership 与 SQL Server Compact (SDF) - 使用现有数据库进行代码优先

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

可能我错过了一些明显的东西,但我无法设法让基于 SDF 的 ASP.NET MVC 4 Web 应用程序与新的简单成员资格一起工作。我详细介绍了我的步骤,以便为其他新手提供引用。

首先,我发现这个新成员(member)系统的介绍非常有用: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>
  • 我更改了 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");
                });
        }
    }
    

    现在,当我运行网络应用程序时,我立即收到一个异常,告诉我找不到 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 模板设置。 那么我怎样才能让它发挥作用呢?

    最佳答案

    在我当前使用 mssql 的 mvc 4 项目中, 这是一个简单的,所以我只想要一个非常简单的成员(member)提供商 我禁用了 初始化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数据库中,应用程序创建了一些表,其中的角色是角色,而UserInRoles只是添加了我需要的角色,例如管理员、客户等... 您可以对数据库执行相同的操作或构建一些界面来管理角色和成员资格。 我通过添加此代码来限制对某些 Controller 或操作的访问

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

    关于asp.net-mvc - SimpleMembership 与 SQL Server Compact (SDF) - 使用现有数据库进行代码优先,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13343875/

    相关文章:

    javascript - 数据注释在部分 ASP.NET MVC 中不起作用 jquery 不显眼的验证

    Visual Studio 2015 中的向导中缺少 PostgreSQL 数据提供程序

    deployment - 使用我的 Windows Mobile 应用程序部署 SQL Server CE

    authentication - 如何在Asp.Net 4.0中实现身份验证和授权?

    asp.net-mvc-4 - ASP.NET MVC 4 Membership "Remember me"如何工作?

    c# - 当 Web API 是 MVC Web 应用程序的一部分时访问受限的 Web API Controller ?

    javascript - 如何在 dropzone.js 中设置上传按钮

    sql - 防止行版本(时间戳)列更改 ALTER TABLE COLUMN

    wcf - WCF 中的 ASP.Net 成员资格提供程序 (WebHttpBinding)

    asp.net-mvc - MVC : Should model inherit from BLL object or containt it?