ASP Identity CoreGeneratePasswordResetTokenAsync 已过期

问题描述 投票:0回答:2

我已经在.NET Core 2.1中设置了Identity Server 4项目,一切正常,但是当我使用用户管理器生成重置密码令牌时,令牌在24小时后过期,我可以将其更改为48小时吗?

我发送重置令牌的代码如下所示:

var code = await _userManager.GeneratePasswordResetTokenAsync(user);

var callbackUrl = url.EmailConfirmationLink(user.Id, code, scheme);

我的配置服务如下所示:

   services.AddIdentity<ApplicationUser, IdentityRole>(config =>
        {
            config.SignIn.RequireConfirmedEmail = true;
        })
            .AddEntityFrameworkStores<ApplicationDbContext>()
            .AddDefaultTokenProviders();

谢谢:)

asp.net asp.net-identity identityserver4 asp.net-core-2.1
2个回答
33
投票

将以下代码添加到 Startup.cs 类中的 ConfigureServices() 方法应该会对您有所帮助。

services.Configure<DataProtectionTokenProviderOptions>(options =>
    options.TokenLifespan = TimeSpan.FromDays(2));

默认令牌寿命为 24 小时(1 天)。请参考githubTokenOptions


0
投票
定期访问

https://area51.stackexchange.com/! 使用尖括号强制链接:你见过吗

© www.soinside.com 2019 - 2024. All rights reserved.