6

对,所以..我想我很困惑!

我有几个使用 ASP.NET Identity 2.1 运行的 ASP.NET MVC 5 站点,一切都很好。我正在创建一个新的 MVC 6 站点,我希望用户在那里使用他们用于其他系统的现有凭据。我已经尝试过以下方法:

  1. 将 ASP.NET 身份 2 数据库迁移到 3(说它不能,因为表已经存在,我认为它会诚实地迁移用户)
  2. 尝试让 MVC 6 与 ASP.NET Identity 2.1 一起工作,但惨遭失败

我只是想知道我的选择是什么,因为新版本的文档不是很好,我知道数据库中有 DDL 更改,但我有点希望我的 MVC 5 网站有办法继续下去.NET Identity 3 数据库向后兼容 2.1。

我的另一个选择是升级 MVC 5 应用程序以使用 Identity 3,这反过来又意味着将它们更新到 MVC 6,这是我没有真正拥有的资源,或者拥有一个全新的 Identity 数据库(看起来最小的选择)。

任何意见都会有所帮助,毫无疑问我错过了一些细节,如果有人对设置有任何进一步的问题,我很乐意填补空白。

4

3 回答 3

3

我正在做同样的事情,这是一个很大的努力 - 你将不得不运行数据库迁移,但首先

ASP Identity V3 表和迁移

ASP Identity V3 表和迁移

ASP Identity V3 字段

用户表中的字段,您可以扩展它,见下文

在 Startup.cs 中配置表并更改 services.AddIdentity

   services.AddIdentity<ApplicationUser, IdentityRole<int>>()
    .AddEntityFrameworkStores<ApplicationDbContext, int>()
    .AddDefaultTokenProviders();

在 ApplicationContext.cs 中,将类更改为以下签名。

 public class ApplicationDbContext : IdentityDbContext<ApplicationUser, IdentityRole<int>, int>

在 ApplicationUser.cs 中,将类更改为以下签名。

`public class ApplicationUser : IdentityUser<int> {...}`
  • 鉴于所有更改,我发现删除迁移文件夹中的所有内容(迁移除外)更容易。转到项目目录上的命令提示符,然后像这样键入/添加迁移dotnet ef migrations add MyDatabaseHere -o Data\Migrations。(-o 选项是指定目标文件夹而不是根文件夹)
  • 对于迁移的任何问题,我只需删除数据库并再次部署即可。
  • 或者你可以用这个自动化我没有试过这个

我从 EF 获得了两个迁移脚本,我不知道为什么......但是从 github 链接12获得更多参考

于 2017-01-18T20:05:07.757 回答
2

实施 IdentityServer3,它可以直接连接到您现有的 ASP.Net Identity EF DB。然后将其他站点用作 oAuth 客户端,作为 MVC 5 和/或 MVC 6,这并不重要,因为它们所做的只是在您的 IdentityServer3 站点之间来回传递安全令牌。

于 2017-06-18T05:10:26.820 回答
1

您可以在 Asp.Net Core 中使用身份 2,并在数据库中保留密码哈希。只需在 startup.cs 中添加此代码

 services.Configure<PasswordHasherOptions>(options => {
          options.CompatibilityMode = PasswordHasherCompatibilityMode.IdentityV2;
      });
于 2018-06-26T15:59:37.367 回答