您可以在很多地方执行此操作。假设您正在执行以下操作来注册用户
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);
}
希望这会有所帮助。