在ASP.NET Core中,电子邮件确认链接的默认有效期是24小时。要使用电子邮件确认链接,可以使用ASP.NET Core Identity库提供的功能。
首先,确保在Startup.cs文件的ConfigureServices方法中添加了Identity服务:
services.AddIdentity()
.AddEntityFrameworkStores()
.AddDefaultTokenProviders();
然后,在注册新用户时生成电子邮件确认链接,并将其发送给用户。可以使用以下代码:
var token = await _userManager.GenerateEmailConfirmationTokenAsync(user);
var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, token = token }, protocol: HttpContext.Request.Scheme);
// 发送电子邮件包含确认链接
在上面的代码中,我们使用UserManager的GenerateEmailConfirmationTokenAsync方法生成了一个令牌。然后,我们使用Url.Action方法生成确认电子邮件的URL,并将其包含在发送给用户的电子邮件中。
最后,当用户点击确认链接时,可以在AccountController中的ConfirmEmail方法中验证令牌的有效性,并确认用户的电子邮件。以下是一个示例:
[HttpGet]
[AllowAnonymous]
public async Task ConfirmEmail(string userId, string token)
{
if (userId == null || token == null)
{
return RedirectToAction("Error", "Home");
}
var user = await _userManager.FindByIdAsync(userId);
if (user == null)
{
return RedirectToAction("Error", "Home");
}
var result = await _userManager.ConfirmEmailAsync(user, token);
if (result.Succeeded)
{
return RedirectToAction("EmailConfirmed", "Account");
}
else
{
return RedirectToAction("Error", "Home");
}
}
在上面的代码中,我们首先检查用户ID和令牌是否存在。然后,我们使用UserManager的FindByIdAsync方法查找用户。接下来,我们使用UserManager的ConfirmEmailAsync方法确认用户的电子邮件。
请注意,以上示例中的代码片段仅用于说明目的,实际实现可能会根据具体的应用程序需求有所不同。