AspNet.Security.OpenIdConnect.Server 令牌吊销和注销不起作用

Posted

技术标签:

【中文标题】AspNet.Security.OpenIdConnect.Server 令牌吊销和注销不起作用【英文标题】:AspNet.Security.OpenIdConnect.Server Token Revocation and Logout is not working 【发布时间】:2019-10-17 00:44:18 【问题描述】:

我已经配置了 revoke 和 logout 端点,如下所述。

.AddOpenIdConnectServer(options =>

    options.LogoutEndpointPath = "/logout";
    options.RevocationEndpointPath = "/revoke";

但两者都不起作用令牌撤销不会过期/撤销令牌。

对于令牌撤销, 我已经调试了代码,发现它在下面提到的代码中拒绝了 OpenIdConnectServerHandler 类中的上下文。

var context = new ValidateRevocationRequestContext(Context, Scheme, Options, request); await Provider.ValidateRevocationRequest(context);

context.IsRejected 经过上述方法后为真

请求(post)包含clientId、clientsecret、作为访问令牌或刷新令牌的令牌和token_hint_type。我无法得出结论为什么会发生这种情况?

更新 1:

通过下面提到的代码验证上下文。

public override async Task ValidateRevocationRequest(ValidateRevocationRequestContext context) context.Validate();

现在我通过调试 ASOS 代码了解到令牌撤销没有内置逻辑,对吗?如果这是这种情况,那么我需要编写我的自定义逻辑来撤销令牌

public override async Task HandleRevocationRequest(HandleRevocationRequestContext context) .. code

现在我想知道撤销令牌(访问和刷新)的方法是什么,因为这些是自包含的,不像 openiddict 那样存储在数据库中(我看过 openiddict 的撤销逻辑)。

【问题讨论】:

【参考方案1】:

现在我通过调试 ASOS 代码了解到令牌撤销没有内置逻辑,对吗?如果这是这种情况,那么我需要编写我的自定义逻辑来撤销令牌

没错:ASOS 是完全无状态的。

如何实施完全由您自己决定。您可以使用表来存储令牌条目,例如 OpenIddict(由 Serialize*Token 事件创建)或带有已撤销令牌标识符的黑名单。

更多信息在这里:AspNet.Security.OpenIdConnect.Server. Refresh tokens

【讨论】:

以上是关于AspNet.Security.OpenIdConnect.Server 令牌吊销和注销不起作用的主要内容,如果未能解决你的问题,请参考以下文章