gpt4 book ai didi

asp.net-mvc - 使用 SQL Server Compact (SDF) 的 SimpleMembership - 先使用现有数据库编写代码

转载 作者:行者123 更新时间:2023-12-04 05:24:35 27 4
gpt4 key购买 nike

可能我遗漏了一些明显的东西,但我无法设法让基于 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 数据库的临时占位符)中的代码优先步骤如下:

  • 我用 VS 2012 创建了一个新的互联网应用程序。
  • 我向 App_Data ( Accounts.sdf ) 添加了一个新的 SDF 文件,并在那里为用户和角色创建了我的表。
  • 我添加了一个新的连接字符串到 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");
    });
    }
    }

    现在,当我运行 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 模板设置。
    那么我怎么能让这个工作呢?

    最佳答案

    在我当前使用 mssql 的 mvc 4 项目中,
    这是一个简单的我,所以我只想要非常简单的成员(member)资格提供者
    我禁用了
    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 只是添加了我需要的角色,如管理员、客户等......
    你可以对你的数据库做同样的事情,或者建立一些界面来管理角色和成员。
    我通过添加此代码来限制对某些 Controller 或操作的访问
    [Authorize(Roles = "Admin")]
    public class MessagesController : Controller

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

    27 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com