Spring Security Oauth2 中实现TokenEnhancer向jwt中添加额外信息

在实现了Oauth2后,我们拿到的jwt中的json是下图的形式。
在这里插入图片描述
这里面的json字段是默认的,如果我们想加入一些额外的有用信息该怎么做?
首先,你要实现TokenEhancer(令牌增强器)中的 ehance方法。
在这里插入图片描述

public class CustomTokenEnhancer implements TokenEnhancer {

    @Override
    public OAuth2AccessToken enhance(OAuth2AccessToken accessToken, OAuth2Authentication authentication) {
        User user = (User) authentication.getPrincipal();
        final Map<String, Object> additionalInfo = new HashMap<>();

        additionalInfo.put("customInfo", "some_stuff_here");
        // 注意添加的额外信息,最好不要和已有的json对象中的key重名,容易出现错误
        //additionalInfo.put("authorities", user.getAuthorities());

        ((DefaultOAuth2AccessToken) accessToken).setAdditionalInformation(additionalInfo);

        return accessToken;
    }
}

接下来,要在你的AuthServerConfig中配置tokenEhancer(令牌增强器)如下图
在这里插入图片描述
代码如下:

@Override
    public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {
//      将增强的token设置到增强链中
        TokenEnhancerChain enhancerChain = new TokenEnhancerChain();
        enhancerChain.setTokenEnhancers(Arrays.asList(customTokenEnhancer(), jwtAccessTokenConverter()));

        endpoints
                .tokenStore(jwtTokenStore())
                .accessTokenConverter(jwtAccessTokenConverter())
                .userDetailsService(userDetailsService)
                .tokenEnhancer(enhancerChain);
    }

 @Bean
    public TokenEnhancer customTokenEnhancer() {
        return new CustomTokenEnhancer();
    }

好了,重启项目。
在这里插入图片描述
在下一篇Spring Security Oauth2 在资源服务器如何获取jwt中的额外信息中,笔者将和大家一起探讨如何从jwt中取出这些额外信息。
不奢求打赏博主,关注点赞走一走,好不好鸭
在这里插入图片描述
spring security oauth2 交流群:
在这里插入图片描述
推荐博客:https://blog.csdn.net/buxiaoxia/article/details/64123823

  • 10
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 20
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 20
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值