Мое приложение MVC было разработано с использованием членства asp.net, теперь я перешел на .net Core, и аутентификация не удалась на _signInManager.PasswordSignInAsync.Но это прекрасно работает, если я создал нового пользователя.
После долгих исследований я обнаружил, что это как-то связано с IdentityV2 и IdentityV3 PasswordHash.Там много статей, но ни у одной из них нет решения, которое я ищу.
Итак, обращаясь ко всем вам, пожалуйста, помогите мне, как обновить хэш пароля до нового хэша пароля или как я могу заставить core2.1 работать.
Любая помощь приветствуется.У меня 2000+ пользователей в старом mvc, и я не могу попросить их сменить пароли.
Заранее спасибо.
Вот код ...
[HttpPost]
public async Task<object> Login([FromBody] LoginViewModel model)
{
if (!ModelState.IsValid)
return View(model);
string user_name = "";
var user = await _userManager.FindByNameAsync(model.Email);
if (user == null)
{
throw new ApplicationException(model.Email + " not Found");
}
var result = await _signInManager.PasswordSignInAsync(user, model.Password, true, false);
//var result = await _signInManager.PasswordSignInAsync(user.UserName, model.Password, true, false);
//var result = await _signInManager.PasswordSignInAsync(model.Email, model.Password, true, false);
if (result.Succeeded)
{
var appUser = _userManager.Users.SingleOrDefault(r => r.Email == model.Email);
return GenerateJwtTokenNew(model.Email, appUser);
}
throw new ApplicationException("INVALID_LOGIN_ATTEMPT");
}