Я хочу, чтобы пользователь добавил свои имена в приложение (и мне удалось его сохранить) и продолжил вход в систему со своей электронной почтой. Но при входе в систему я получаю «Недопустимая попытка входа» и не понимаю, почему ...
В модель (AccountViewModel
) я добавил Имя:
[Required]
public string Name { get; set; }
В AccountController
я внес следующие изменения, чтобы сохранить значение при регистрации
var user = new ApplicationUser {
UserName = model.Name,
Email = model.Email
};
И в Register.cshtml
добавлено поле для хранения их имени
<div class="form-group">
@Html.LabelFor(m => m.Name, new { @class = "col-md-2 control-label" })
<div class="col-md-10">
@Html.TextBoxFor(m => m.Name, new { @class = "form-control" })
</div>
</div>
Единственные изменения, которые я сделал, были UserName
, а не Email
. Поскольку при входе в систему используется электронная почта, я не уверен, почему это должно быть затронуто.
// POST: /Account/Login
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Login(LoginViewModel model, string returnUrl)
{
if (!ModelState.IsValid)
{
return View(model);
}
// This doesn't count login failures towards account lockout
// To enable password failures to trigger account lockout, change to shouldLockout: true
var result = await SignInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, shouldLockout: false);
switch (result)
{
case SignInStatus.Success:
return RedirectToLocal(returnUrl);
case SignInStatus.LockedOut:
return View("Lockout");
case SignInStatus.RequiresVerification:
return RedirectToAction("SendCode", new { ReturnUrl = returnUrl, RememberMe = model.RememberMe });
case SignInStatus.Failure:
default:
ModelState.AddModelError("", "Invalid login attempt.");
return View(model);
}
}