扩展asp.net身份用户导致数据库错误

时间:2016-12-03 15:56:54

标签: c# asp.net-mvc asp.net-identity-2

我尝试使用" Name"扩展asp.net身份用户。因此,我遵循了这篇文章How to extend available properties of User.Identity

中的描述

但是在我这样做并试图登录之后我得到了这个错误"该模型支持' ApplicationDbContext'自创建数据库以来,上下文已更改。考虑使用Code First Migrations来更新数据库"

我可以修复此问题,还是只能在第一次创建数据库之前扩展asp.net ueser标识?

1 个答案:

答案 0 :(得分:0)

Based on Asp.Net template database will generate the bellow structure: 

enter image description here

    In order to extend asp.net identity user and keep the things simple, please update IdentityModels.cs with following code: 

//CODE

    using System.Data.Entity;
    using System.Security.Claims;
    using System.Threading.Tasks;
    using Microsoft.AspNet.Identity;
    using Microsoft.AspNet.Identity.EntityFramework;
    using System.Data.Entity.Migrations;

namespace WebApplication.Models
{
    // You can add profile data for the user by adding more properties to your ApplicationUser class, please visit http://go.microsoft.com/fwlink/?LinkID=317594 to learn more.
    public class ApplicationUser : IdentityUser
    {
        public string Name { get; set; }
        public async Task<ClaimsIdentity> GenerateUserIdentityAsync(UserManager<ApplicationUser> manager)
        {
            // Note the authenticationType must match the one defined in CookieAuthenticationOptions.AuthenticationType
            var userIdentity = await manager.CreateIdentityAsync(this, DefaultAuthenticationTypes.ApplicationCookie);
            // Add custom user claims here
            return userIdentity;
        }
    }

    public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
    {
        public ApplicationDbContext()
            : base("DefaultConnection", throwIfV1Schema: false)
        {
            Database.SetInitializer(new MigrateDatabaseToLatestVersion<ApplicationDbContext, ApplicationDbContextConfiguration>());
        }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
            modelBuilder.Entity<IdentityRole>().ToTable("AspNetRoles");
            modelBuilder.Entity<IdentityUserRole>().ToTable("AspNetUserRoles");
            modelBuilder.Entity<IdentityUserLogin>().ToTable("AspNetUserLogins");
            modelBuilder.Entity<IdentityUserClaim>().ToTable("AspNetUserClaims");
            modelBuilder.Entity<ApplicationUser>().ToTable("AspNetUsers");
        }


        public static ApplicationDbContext Create()
        {
            return new ApplicationDbContext();
        }
    }



    internal sealed class ApplicationDbContextConfiguration : DbMigrationsConfiguration<ApplicationDbContext>
    {
        public ApplicationDbContextConfiguration()
        {

            ContextKey = "WebApplication.Models.ApplicationDbContext"; //Retrieved from the database table dbo.__MigrationHistory

#if DEBUG
            AutomaticMigrationsEnabled = true;
            AutomaticMigrationDataLossAllowed = true;
#else
                AutomaticMigrationsEnabled = false;
                AutomaticMigrationDataLossAllowed = false;

#endif
        }

        protected override void Seed(ApplicationDbContext context)
        {
            base.Seed(context);
        }
    }
} 


The output is: 

enter image description here

PS: You can rename default names for asp.net generated tables, personally I prefer to remove AspNet suffix