AcquireTokenAsync 不返回新令牌

时间:2021-07-20 16:24:45

标签: c# authentication asp.net-web-api dotnet-httpclient bearer-token

我的 WebAPI 应用程序在启动时从服务获取令牌。此令牌随后将用于共享 HTTP 客户端以防止端口耗尽。

当此令牌即将到期时,我想获取一个新令牌并将其保存在我的服务中以供重复使用。

在我的实现中,检索了一个令牌 - 但是它与原始令牌具有相同的到期时间:

    // Retrieve the token and assign to AuthenticationResult
    private async Task GetAPIToken()
    {
        AuthenticationContext authContext = new AuthenticationContext(Authority);
        var clientCredential = new ClientCredential(clientId, clientSecret);

        // Same token after multiple calls
        AuthenticationResult = await authContext.AcquireTokenAsync(resourceId, clientCredential).ConfigureAwait(false);
    }

如何保存最新的身份验证令牌?

1 个答案:

答案 0 :(得分:2)

这里的问题是 AuthenticationContext authContext = new AuthenticationContext(Authority); 将缓存令牌并在令牌未过期时检索它。

禁用缓存并自己管理令牌生命周期是一种解决方案:

AuthenticationContext authContext = new AuthenticationContext(Authority, null);