Eug*_*ene 4 c# asp.net-core asp.net-core-identity
我希望只有当他/她输入正确的旧密码时才能更改当前用户密码,如下所示:
但我一直在努力在这里和其他地方找到一个优雅的解决方案,
我当前的解决方案如下所示:
var oldPasswordHashed = _userManager.PasswordHasher.HashPassword(appUser, model.OldPassword);
if (oldPasswordHashed == appUser.PasswordHash)
{
var result = await _userManager.ChangePasswordAsync(appUser, appUser.PasswordHash, model.NewPassword);
if (!result.Succeeded)
{
ModelState.AddModelError(nameof(EditUserViewModel.OldPassword), "Error at changing password, retry later.");
return View(model);
}
}
Run Code Online (Sandbox Code Playgroud)
该ChangePasswordAsync()方法期望旧密码不被散列。
试试这个吧。
_userManager.ChangePasswordAsync(appUser, model.OldPassword, model.NewPassword);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1729 次 |
| 最近记录: |