ASP.NET Core 定时刷新第三方 Token

Posted dotNET跨平台

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ASP.NET Core 定时刷新第三方 Token相关的知识,希望对你有一定的参考价值。

前言

在《ASP.NET Core 自动刷新JWT Token》中我们实现了为客户端自动提供最新的Token。

但是,当我们的 ASP.NET Core 应用需要调用第三方 API 时,如何更优雅地刷新第三方提供的 Token 呢?

思路

我们可以在启动时就获取第三方提供的 Token 并保存到全局变量,然后在 Token 过期时间内定时获取第三方最新的 Token 并更新全局变量。

这样每次调用 HttpClient 访问第三方 API 时,都是使用的准备好的 Token, 保证没有过期。

实现

创建一个后台服务 BackgroundService,然后在其 ExecuteAsync 方法中创建一个定时器 PeriodicTimer,定时刷新 Token:

public class RefreshTokenService : BackgroundService, IDisposable

    private readonly ITokenManager tokenManager;

    public RefreshTokenService(ITokenManager tokenManager)
    
        this.tokenManager = tokenManager;
    

    protected async override Task ExecuteAsync(CancellationToken stoppingToken)
    
         tokenManager.Token = await GetToken();

        //30 分钟刷新一次
        var timer = new PeriodicTimer(TimeSpan.FromMinutes(30));

        while (await timer.WaitForNextTickAsync(stoppingToken))
        
            tokenManager.Token = await GetToken();
        
    

    private async Task<string>  GetToken()
    
        //调用第三方服务获取Token
    

接口ITokenManager定义如下,用于存储 Token:

public interface ITokenManager

    string Token  get; set; 

最后,我们在启动时进行依赖注入:

builder.Services.AddSingleton<ITokenManager,TokenManager>();

builder.Services.AddHostedService<RefreshTokenService>();

结论

现在,任何注入ITokenManager的类,都能始终获得有效的 Token 了。

添加微信号【MyIO666】,邀你加入技术交流群

以上是关于ASP.NET Core 定时刷新第三方 Token的主要内容,如果未能解决你的问题,请参考以下文章

ASP.NET Core2.2+Quartz.Net 实现web定时任务

C# Jwt 令牌生成失败 asp.net core 2.2

2步轻松实现ASP.NET Core托管服务执行定时任务

在 ASP.Net Core Identity 中刷新用户 cookie 票证

ASP.net Core 2.0 JWT 令牌刷新

使用 AspNetUserTokens 表在 ASP.NET Core Web Api 中存储刷新令牌