ASP.NET Identity 3.0上IIdentityMessageService的等价物是什么?

时间:2015-09-12 15:04:42

标签: c# asp.net-identity asp.net-identity-3

在ASP.NET Identity 2.X上,我们可以配置一个通知基础架构,以及IIdentityMessageService库中可用的Microsoft.AspNet.Identity.Core接口,该接口未升级到3.0版。

在ASP.NET Identity 3.0上配置消息传递基础结构的做法是什么?

1 个答案:

答案 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;
}