gpt4 book ai didi

c# - 带有自定义表的 Identity 2.0

转载 作者:IT王子 更新时间:2023-10-29 04:12:52 24 4
gpt4 key购买 nike

我是 ASP.NET 身份的新手,我仍在努力了解它是如何工作的。不幸的是,我发现我试过的许多教程都是针对 Identity 1.0 的,而我正在尝试使用 Identity 2.0。

我面临的最大问题是我认为很简单,但事实证明并非如此。我想要做的是将现有数据库与现有用户表一起使用。目前我似乎能做的就是让 Identity 创建它自己的表来存储用户数据。我不想使用 Entity Framework,但我很难将 Entity Framework 与 Identity 2.0 分开。

虽然我的情况是使用 SQL Server,但我想我会尝试通过以下链接为 MySQL 实现自定义提供程序:http://www.asp.net/identity/overview/extensibility/implementing-a-custom-mysql-aspnet-identity-storage-providerhttps://github.com/raquelsa/AspNet.Identity.MySQL .这似乎仅在身份 1 下有效。似乎确实有一个更新的,但是它使用 Entity Framework 。我也试过 https://github.com/ILMServices/RavenDB.AspNet.Identity .

在我尝试过的所有方法中,我都卡在了以下行中:

var manager = new IdentityUserManager(new UserStore<IdentityUser>(context.Get<ApplicationDbContext>()));

我面临的问题是我需要根据 RavenDB 的说明删除 ApplicaitonDbContext 类,但是我不知道该在这一行中放入什么。

我得到的错误是:

The non-generic type 'AspNet.Identity.MySQL.UserStore' cannot be used with type arguments

The type or namespace name 'ApplicationDbContext' could not be found (are you missing a using directive or an assembly reference?)

第二个错误是意料之中的,但我不确定在这行代码中使用什么来代替。有没有人有过在不使用 Entity Framework 的情况下实现自定义提供程序的经验?

谢谢。

更新 1:

我尝试了以下教程 [ http://aspnetguru.com/customize-authentication-to-your-own-set-of-tables-in-asp-net-mvc-5/ ] 但它似乎不完整,在完全按照教程进行操作时会出现编译或运行时错误。我还有一些问题是...

当用“User”替换“ApplicationUser”的所有实例时,IdentityConfig.cs 中的以下行有问题

var manager = new ApplicationUserManager(new UserStore<ApplicationUser>(context.Get<MyDbContext>()));

将 ApplicationUser 更改为 User 会产生以下错误

The type 'WebApplicationTest2.Models.User' cannot be used as type parameter 'TUser' in the generic type or method 'Microsoft.AspNet.Identity.EntityFramework.UserStore'. There is no implicit reference conversion from 'WebApplicationTest2.Models.User' to 'Microsoft.AspNet.Identity.EntityFramework.IdentityUser'.

我也很难弄清楚如何使用用户管理器和许多 ASync 方法。以下几行不起作用:

AuthenticationManager.SignIn(new AuthenticationProperties() { IsPersistent = isPersistent }, await user.GenerateUserIdentityAsync(UserManager));

在 AccountController.cs 中出现以下错误:

The best overloaded method match for 'Microsoft.Owin.Security.IAuthenticationManager.SignIn(Microsoft.Owin.Security.AuthenticationProperties, params System.Security.Claims.ClaimsIdentity[])' has some invalid arguments.

'WebApplicationTest2.Models.User' does not contain a definition for 'GenerateUserIdentityAsync' and no extension method 'GenerateUserIdentityAsync' accepting a first argument of type 'WebApplicationTest2.Models.User' could be found (are you missing a using directive or an assembly reference?)

最佳答案

在您的示例中,您似乎想要替换 DbContext与其他东西,但我相信实际上,你需要将你的努力集中在一个更高的层次上。

框架有一个类 UserManager负责管理但不存储用户及其相关信息。当它想要存储用户(或他们的相关信息)时,默认是使用提供的 UserStore<IdentityUser>哪个知道如何存储IdentityUser使用 DbContext 的数据库中的实例.

在 2.0 框架中,身份存储的各个部分被分成几个接口(interface)。提供的默认实现,UserStore<IdentityUser>实现其中几个接口(interface)并使用 DBContext 将它们的数据全部存储在数据库中.

如果您查看默认提供的基于 UserStore 的 Entity Framework 的定义,您会发现它实现了许多这些小接口(interface):

public class UserStore<TUser, TRole, TKey, TUserLogin, TUserRole, TUserClaim> : IUserLoginStore<TUser, TKey>, 
IUserClaimStore<TUser, TKey>, IUserRoleStore<TUser, TKey>, IUserPasswordStore<TUser, TKey>,
IUserSecurityStampStore<TUser, TKey>, IQueryableUserStore<TUser, TKey>, IUserEmailStore<TUser, TKey>,
IUserPhoneNumberStore<TUser, TKey>, IUserTwoFactorStore<TUser, TKey>, IUserLockoutStore<TUser, TKey>,
IUserStore<TUser, TKey>, IDisposable
where TUser : IdentityUser<TKey, TUserLogin, TUserRole, TUserClaim>
where TRole : IdentityRole<TKey, TUserRole>
where TKey : Object, IEquatable<TKey>
where TUserLogin : new(), IdentityUserLogin<TKey>
where TUserRole : new(), IdentityUserRole<TKey>
where TUserClaim : new(), IdentityUserClaim<TKey>

由于您根本不想使用 Entity Framework,因此您需要提供自己对其中一些关键接口(interface)的实现,这些接口(interface)会将数据存储在您希望存储数据的位置。主界面为 IUserStore<Tuser,TKey> .这定义了用于存储具有特定类型 key 的用户的契约(Contract)。如果您只想存储用户而没有其他信息,那么您可以实现此接口(interface),然后将您的实现传递给 UserManager你应该可以开始了。

这不太可能就足够了,尽管您可能需要用户的密码、角色、登录名等。如果是这样,那么您需要创建实现 IUserStore<Tuser,TKey> 的类还执行 IUserPasswordStore<TUser, TKey> , IRoleStore<TRole, TKey>IUserClaimStore<TUser, TKey> .

您可以找到所有接口(interface)的列表on MSDN here

根据您要使用的位,您需要实现这些接口(interface)。

您可能还需要定义自己的 Identity* 版本Entity framework already out of the box 存在的类.所以你需要自己的IdentityUser表示您要存储的用户的类,以及 IdentityUserClaim为用户 claim 。我自己还没有这样做,所以我不太确定,但我的感觉是您必须这样做。

Scott Allen 有一个 good article关于可能有用的模型的各个部分。

至于您对这一行的问题:

AuthenticationManager.SignIn(new AuthenticationProperties() { IsPersistent = isPersistent }, await user.GenerateUserIdentityAsync(UserManager));

有一个方法叫GenerateUserIdentityAsync这是在 Applicationuser 上定义的延伸IdentityUser .它是在我相信的模板项目中定义的,看起来像这样:

public class ApplicationUser : IdentityUser 
{
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;
}
}

因为您没有使用 Entity Framework IdentityUser那么你要么需要定义一个类似的方法,要么你自己的 User类或以其他方式实现相同的功能(比如只调用 await manager.CreateIdentityAsync(this, DefaultAuthenticationTypes.ApplicationCookie) 而不是)

关于c# - 带有自定义表的 Identity 2.0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24428520/

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