我正在尝试创建具有 N 层架构和自定义 ASP.NET 身份服务和存储库 ASP.NET MVC 项目。我已经实现了自定义用户存储
UserStore: UserIUserStore<User>, IUserPasswordStore<User>, IUserRoleStore<User>, IUserLoginStore<User>, IUserEmailStore<User>
我已经实现了注册和登录。现在我想通过社交网络实现登录,但我卡住了。
public class User : IUser<string>
{
[Required]
public string Id { get; set; }
[Required]
public string UserName { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
[Required]
[DataType(DataType.EmailAddress)]
public string Email { get; set; }
[Required]
public string PasswordHash { get; set; }
public virtual ICollection<Role> Roles { get; set; }
public virtual ICollection<UserLoginInfo> Logins { get; set; }
}
UserLoginInfo是IUserLoginStore中用于登录信息的sealead类。但是,如果我想添加迁移,则出现此错误:
NtierMVC.Repositories.UserLoginInfo: : EntityType 'UserLoginInfo' has no key defined. Define the key for this EntityType.
Login: EntityType: EntitySet 'Login' is based on type 'UserLoginInfo' that has no keys defined.
我试图找到任何解决方案,如何将带有外键的登录表扩展到用户(例如,如果您使用默认用户存储),但没有找到。知道吗?
谢谢你的帮助。
好吧,我用自定义登录类解决了。
public class ExternalLogin
{
public string UserId { get; set; }
[Key, Column(Order = 0)]
public string LoginProvider { get; set; }
[Key, Column(Order = 1)]
public string ProviderKey { get; set; }
public UserLoginInfo GetUserLoginInfo()
{
return new UserLoginInfo(LoginProvider, ProviderKey);
}
}
public class User : IUser<string>
{
// user properties
public virtual ICollection<ExternalLogin> Logins { get; set; }
}