ASP.Net Identity 存在一些问题。我正在通过以下方式创建用户:
var manager = new UserManager<IdentityUser>(userStore);
manager.UserValidator = new UserValidator<IdentityUser>(manager)
{
AllowOnlyAlphanumericUserNames = false
};
manager.PasswordValidator = new PasswordValidator
{
RequiredLength = 6,
RequireDigit = true,
RequireLowercase = true,
RequireUppercase = true,
};
var user = new IdentityUser() { UserName = email.Text, Email = email.Text };
IdentityResult result = manager.Create(user, Password1.Text);
然后将用户添加到数据库中。当我尝试使用该用户登录时,它总是返回“密码不正确”,即使密码与用于创建帐户的密码相同。
我正在使用以下方法登录:
var userStore = new UserStore<IdentityUser>();
var userManager = new UserManager<IdentityUser>(userStore);
userManager.UserValidator = new UserValidator<IdentityUser>(userManager)
{
AllowOnlyAlphanumericUserNames = false
};
var user = userManager.Find(email.Text, Password.Text);
if (user != null)
使用 SQL Profiler 我可以看到它正确查找用户,当我在 SSMS 中运行 SQL 时,我可以看到该行返回正常。
当从数据库返回的实际记录数为 1 时,我不确定为什么 userManager.Find 返回 null?
使用 SignInManager
SignInManager<IdentityUser> _signInManager; // Inject
var result = await _signInManager.PasswordSignInAsync(email.Text, Password.Text, true, lockoutOnFailure: true);
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句