如何在春季授权服务器中丰富JWT?
我有一个带有微服务体系结构的SaaS服务器。身份验证是由新的 Spring授权服务器。对于某些领域的情况,我希望能够重新评估登录用户的JWT,而无需强迫用户再次输入其密码以通过其他索赔来丰富他们的令牌。
:登录用户使用索赔集
A。
拥有 像这样:
@PostMapping("/renew")
public Authentication token() {
return jwtAuthenticationProvider.authenticate(
new BearerTokenAuthenticationToken(JwtUtil.getCurrentAuthenticationTokenValue())
);
}
where jwtutil.getCurrentAuthenticationTokenValue()
从security> security> security> securitycontextholder
提取登录的用户令牌值。此设置没有创建新的令牌,并像没有触发身份验证过程一样返回旧的令牌。
但是我找不到在Spring授权服务器中生成新令牌的函数/服务。
PS。我不能使用RefReshToken来获取新的访问权限,因为我的客户端是公开的,并且根据 this ,仅向机密客户发行重新刷新。
I have a SAAS server with microservice architecture. Authentication is done by the new Spring authorization server. For some domain situation, I want to be able to re-issue a JWT for a logged-in user without forcing the user to enter their password again to enrich their token with additional claims.
Having: Logged-in user with claim set A.
Required: Create a new token for the user with claim set B. (Without user intervention)
I'm looking for something like this:
@PostMapping("/renew")
public Authentication token() {
return jwtAuthenticationProvider.authenticate(
new BearerTokenAuthenticationToken(JwtUtil.getCurrentAuthenticationTokenValue())
);
}
Where JwtUtil.getCurrentAuthenticationTokenValue()
extracts logged-in user token value from SecurityContextHolder
. This setup creates no new token and returns the old one like no authentication process has been triggered.
But I cannot find a function/service that generates a new token in spring authorization server.
PS. I cannot use RefreshToken to get new AccessToken because my client is public and according to this, RefreshToken only is issued for confidential clients.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您可以阅读有关 oauth2tokencustomizer 在文档中。这是自定义访问令牌的一个示例:
在您的情况下,您可以向授权端点(例如
get> get/oauth2/授权?...
)向客户发出新请求。 >授权_Code带有不同范围或其他请求参数的流动,并使用自定义器添加您需要的任何要求。根据您提供的信息,这是使用授权服务器发布新令牌的建议方法。添加自定义端点以执行与OAUTH2相关的操作(例如自定义
/续订
端点),而无需合并规范的最佳实践和标准不是不建议。You can read about OAuth2TokenCustomizer in the docs. Here's an example of customizing the access token:
In your case, you could issue a new request to the authorization endpoint (e.g.
GET /oauth2/authorize?...
) from the client to begin theauthorization_code
flow with different scopes or additional request parameters and use the customizer to add whatever claims you need. Based on the information you've provided, this would be the recommended way to use the authorization server to issue new tokens.Adding custom endpoints to perform OAuth2-related actions (such as a custom
/renew
endpoint) without incorporating best practices and standards from the specification(s) would not be recommended.