在ASP.NET Identity 2.X上,我们可以配置一个通知基础架构,以及IIdentityMessageService
库中可用的Microsoft.AspNet.Identity.Core
接口,该接口未升级到3.0版。
在ASP.NET Identity 3.0上配置消息传递基础结构的做法是什么?
答案 0 :(得分:12)
似乎没有更多的电子邮件服务插入Asp.Net Identity。您只需定义自己的界面即可。 ASP.NET标识的作用是生成并验证电子邮件确认令牌和密码重置令牌。
public interface IEmailService
{
Task SendAsync(string to, string subject, string body);
}
private async Task SendEmailConfirmation(User user)
{
string token = await this._userManager.GenerateEmailConfirmationTokenAsync(user);
string callbackUrl = this._urlHelper.Action("EmailConfirmed", "Account", new ConfirmTokenViewModel(user.Id, token), protocol: this._contextAccessor.HttpContext.Request.Scheme);
await this._emailService.SendAsync(to: user.Email,
subject: "Confirm your account",
body: "Please confirm your e-mail by clicking this link: <a href=\"" + callbackUrl + "\">link</a>");
}
OBS:this._urlHelper是一个IUrlHelper。它可以是属性Controller.Url或由构造函数注入生成的新实例。
然后,确认电子邮件
[HttpGet]
[AllowAnonymous]
public async Task<IActionResult> EmailConfirmed(ConfirmTokenViewModel model)
{
if (!this.ModelState.IsValid)
return View("Error");
bool succeeded = await this._accountsManager.ConfirmEmail(model.UserId, model.Token);
return succeeded ? View() : View("Error");
}
public async Task<bool> ConfirmEmail(string userId, string token)
{
User user = await _userManager.FindByIdAsync(userId);
if (user != null)
{
var result = await _userManager.ConfirmEmailAsync(user, token);
return result.Succeeded;
}
return false;
}
public async Task GeneratePasswordTokenAndSendEmailAsync(string email)
{
var user = await _userManager.FindByNameAsync(email);
if (user != null && await _userManager.IsEmailConfirmedAsync(user))
{
string token = await _userManager.GeneratePasswordResetTokenAsync(user);
string callbackUrl = this._urlHelper.Action("ResetPassword", "Account", new ConfirmTokenViewModel(user.Id, token), protocol: this._contextAccessor.HttpContext.Request.Scheme);
await this._emailService.SendAsync(
to: user.Email,
subject: "Reset password",
body: "Reset your password by clicking this link: <a href=\"" + callbackUrl + "\">link</a>"
});
}
}
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task<IActionResult> ResetPassword(ResetPasswordViewModel model)
{
if (ModelState.IsValid)
{
IdentityResult result = await this._accountsManager.ResetPasswordAsync(model);
if (result.Succeeded)
{
return RedirectToAction(nameof(ResetPasswordConfirmation), "Account");
}
else
ModelState.AddModelErrors(result.Errors);
}
// If we got this far, something failed, redisplay form
return View(model);
}
public async Task<IdentityResult> ResetPasswordAsync(ResetPasswordViewModel model)
{
IdentityResult result = IdentityResult.Success;
if (model != null && !string.IsNullOrWhiteSpace(model.UserId))
{
User user = await _userManager.FindByIdAsync(model.UserId);
if (user != null)
result = await _userManager.ResetPasswordAsync(user, model.Token, model.Password);
}
return result;
}