我在Asp.Net Identity API 2.0中面临一个奇怪的问题。
用户注册后,我会向用户发送确认电子邮件,如果用户在注册后3个小时内确认了他/她的帐户,则“ ConfirmEmailAsync”方法似乎可以正常工作。
但是3小时后,如果我尝试确认电子邮件地址,则会收到“无效令牌”错误。
然后,如果用户尝试再次注册,则会收到“电子邮件/名称已被占用”的错误消息。
我该如何解决用户被“锁定”,他无法登录,也无法从头开始注册的情况。
有人可以帮忙吗?
您可以在许多地方执行此操作。例如,您正在执行以下操作来注册用户
var user = new ApplicationUser { UserName = model.RegisterEmail.ToLower(), Email = model.RegisterEmail.ToLower(), PhoneNumber = model.RegisterPhoneNumber, EmailConfirmed = true, PhoneNumberConfirmed = true };
var addUserResult = await UserManager.CreateAsync(user, model.RegisterPassword);
if (!addUserResult.Succeeded)
{
ApplicationUser user = await UserManager.FindByEmailAsync(model.RegisterEmail.ToLower());
if(!user.EmailConfirmed)
{
var code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
//Send the new link
//return the error message accordingly.
}
}
您可以在登录期间执行相同的操作
ApplicationUser user = await UserManager.FindAsync(model.UserName.ToLower(), model.Password);
if(user != null && !user.EmailConfirmed)
{
var code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
//Send the new link
//return the error message accordingly.
}
或者,如果您使用的是SigninManager(这是来自默认的MVC模板)
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:
//redirecting to a different page
return RedirectToAction("SendCode", new { ReturnUrl = returnUrl, RememberMe = model.RememberMe });
case SignInStatus.Failure:
default:
ModelState.AddModelError("", "Invalid login attempt.");
return View(model);
}
希望这可以帮助。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句