我遇到自定义用户的问题。 我有一个名为配置文件的表,我将其用于我的用户表(它不会让我使用用户,但这是一个不同的问题!)我创建了我的dbcontext,如下所示:
public partial class SkipstoneContext : IdentityDbContext<Profile>
{
static SkipstoneContext()
{
Database.SetInitializer<SkipstoneContext>(null); // Existing data, do nothing
}
public SkipstoneContext()
: base("DefaultConnection")
{
}
// ...
public DbSet<Company> Companies { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<IdentityUserLogin>().HasKey<string>(model => model.UserId);
modelBuilder.Entity<IdentityRole>().HasKey<string>(model => model.Id);
modelBuilder.Entity<IdentityUserRole>().HasKey(model => new { model.RoleId, model.UserId });
modelBuilder.Entity<UserSecret>().HasKey<string>(model => model.UserName);
}
}
如您所见,我没有必要为个人资料创建 DbSet ,因为这是在继承的 IdentityDbContext 类中设置的
我的个人资料类看起来像这样:
public partial class Profile : IdentityUser
{
public Profile()
{
// ...
}
public string CompanyId { get; set; }
public string Title { get; set; }
public string Forename { get; set; }
public string Surname { get; set; }
public string Email { get; set; }
// ...
public virtual Company Company { get; set; }
// ...
}
当我运行我的项目时,我收到一条错误说明
无效的对象名称'dbo.IdentityUsers'。
如果我将表格重命名为 IdentityUsers 并再次运行该项目,则会收到错误消息
无效的对象名称'dbo.Profiles'。
这就是令人困惑的事情。看起来EF正在为用户寻找2个表而不仅仅是那个表。
任何人都可以向我解释原因吗?
更新1
因此,为了试图解决这个问题,我从 SkipstoneContext 中删除了继承的 IdentityDbContent ,而只是从 DbContext 继承而来。 新的上下文类如下所示:
public partial class SkipstoneContext : DbContext // : IdentityDbContext<Profile>
{
static SkipstoneContext()
{
Database.SetInitializer<SkipstoneContext>(null); // Exsting database, do nothing
}
public SkipstoneContext()
: base("DefaultConnection")
{
}
// ...
public DbSet<Company> Companies { get; set; }
public DbSet<Profile> Profiles { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
// ...
modelBuilder.Configurations.Add(new CompanyMap());
modelBuilder.Configurations.Add(new ProfileMap());
/// ...
//modelBuilder.Entity<IdentityUserLogin>().HasKey<string>(model => model.UserId);
//modelBuilder.Entity<IdentityRole>().HasKey<string>(model => model.Id);
//modelBuilder.Entity<IdentityUserRole>().HasKey(model => new { model.RoleId, model.UserId });
//modelBuilder.Entity<UserSecret>().HasKey<string>(model => model.UserName);
}
}
我还注释了我对 IdentityUserLogin , IdentityRole , IdentityUserRole 和 UserSecret 的绑定,这就是它的时候开始工作了。
以下是 IdentityUserLogin :
public class IdentityUserLogin
{
public IdentityUserLogin();
public virtual string LoginProvider { get; set; }
public virtual string ProviderKey { get; set; }
public virtual IdentityUser User { get; set; }
public virtual string UserId { get; set; }
}
它有一个 IdentityUser 属性,我认为这就是造成我的问题的原因。我知道个人资料会继承 IdentityUser ,但出于某种原因,它似乎认为它在另一个表中。
所以,我的下一个任务是创建一个自定义UserLogin,看看我是否可以让EF使用 IdentityUserLogin
的实例答案 0 :(得分:1)
好的,我想出来了。这是由于我的映射。我有 Profile 映射类,如下所示:
public class ProfileMap : EntityTypeConfiguration<Profile>
{
public IdentityUserMap()
{
// Primary Key
this.HasKey(t => t.Id);
// Properties
this.Property(t => t.Id)
.IsRequired()
.HasMaxLength(128);
this.Property(t => t.CompanyId)
.IsRequired()
.HasMaxLength(128);
this.Property(t => t.CreatedById)
.IsRequired()
.HasMaxLength(128);
this.Property(t => t.ModifiedById)
.HasMaxLength(128);
this.Property(t => t.Title)
.IsRequired();
this.Property(t => t.Forename)
.IsRequired();
this.Property(t => t.Surname)
.IsRequired();
this.Property(t => t.Email)
.IsRequired();
this.Property(t => t.CredentialId)
.IsRequired();
this.Property(t => t.PasswordHash)
.HasMaxLength(128);
this.Property(t => t.SecurityStamp)
.HasMaxLength(128);
this.Property(t => t.Discriminator)
.HasMaxLength(128);
// Table & Column Mappings
this.ToTable("Profiles");
this.Property(t => t.Id).HasColumnName("Id");
this.Property(t => t.CompanyId).HasColumnName("CompanyId");
this.Property(t => t.CreatedById).HasColumnName("CreatedById");
this.Property(t => t.ModifiedById).HasColumnName("ModifiedById");
this.Property(t => t.DateCreated).HasColumnName("DateCreated");
this.Property(t => t.DateModified).HasColumnName("DateModified");
this.Property(t => t.LastLoginDate).HasColumnName("LastLoginDate");
this.Property(t => t.Title).HasColumnName("Title");
this.Property(t => t.Forename).HasColumnName("Forename");
this.Property(t => t.Surname).HasColumnName("Surname");
this.Property(t => t.Email).HasColumnName("Email");
this.Property(t => t.JobTitle).HasColumnName("JobTitle");
this.Property(t => t.Telephone).HasColumnName("Telephone");
this.Property(t => t.Mobile).HasColumnName("Mobile");
this.Property(t => t.Photo).HasColumnName("Photo");
this.Property(t => t.LinkedIn).HasColumnName("LinkedIn");
this.Property(t => t.Twitter).HasColumnName("Twitter");
this.Property(t => t.Facebook).HasColumnName("Facebook");
this.Property(t => t.Google).HasColumnName("Google");
this.Property(t => t.Bio).HasColumnName("Bio");
this.Property(t => t.CompanyName).HasColumnName("CompanyName");
this.Property(t => t.CredentialId).HasColumnName("CredentialId");
this.Property(t => t.IsLockedOut).HasColumnName("IsLockedOut");
this.Property(t => t.IsApproved).HasColumnName("IsApproved");
this.Property(t => t.CanEditOwn).HasColumnName("CanEditOwn");
this.Property(t => t.CanEdit).HasColumnName("CanEdit");
this.Property(t => t.CanDownload).HasColumnName("CanDownload");
this.Property(t => t.RequiresApproval).HasColumnName("RequiresApproval");
this.Property(t => t.CanApprove).HasColumnName("CanApprove");
this.Property(t => t.CanSync).HasColumnName("CanSync");
this.Property(t => t.AgreedTerms).HasColumnName("AgreedTerms");
this.Property(t => t.Deleted).HasColumnName("Deleted");
this.Property(t => t.UserName).HasColumnName("UserName");
this.Property(t => t.PasswordHash).HasColumnName("PasswordHash");
this.Property(t => t.SecurityStamp).HasColumnName("SecurityStamp");
this.Property(t => t.Discriminator).HasColumnName("Discriminator");
// Relationships
}
}
如您所见,陈述
的行this.ToTable( “配置文件”);
这是造成问题的那一行。改变这个解决了我的问题。