本篇内容主要讲解“spring cloud oauth3整合JWT后获取用户信息不全怎么办”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“spring cloud oauth3整合JWT后获取用户信息不全怎么办”吧!
oauth3整合JWT完成后,发现获取当前认证用户信息(Principal)时只获取到用户名称,没有其他的信息
看了一下oauth3源码,通过分析oauth3加载TokenStore找到解决方案。
oauth3会在DefaultUserAuthenticationConverter下提取认证用户,并给Principal进行赋值
因为userDetailsService没有被注入进去,所以获取的Principal的值只有“admin”。问题是什么时候注入userDetailsService
userDetailsService是当前类的属性,这就好办了。
接着看这个类DefaultAccessTokenConverter,这个类定义了DefaultUserAuthenticationConverter,并调用了DefaultUserAuthenticationConverter.extractAuthentication的方法
看到这里我们发现,找到这个类DefaultAccessTokenConverter的注入就可以了。
接下来是这个类JwtAccessTokenConverter,这里定义了DefaultAccessTokenConverter,调用了DefaultAccessTokenConverter.extractAuthentication的方法,是不是感觉和上一个套路一样。
JwtTokenStore大家应该很熟悉,就是定义了JwtAccessTokenConverter,并调用JwtAccessTokenConverter.extractAuthentication但是没有具体实现,可以通过构造方法进行注入。
看到这里就找到了userDetailsService应该怎么注入进去了。另外,大家也可以关注一下这个类的另一个方法
其实是这个方法调用的上个方法,这个方法被调用在在DefaultTokenServices这个类里
打开这个类DefaultTokenServices看看,你就会发现这个类定义了token的一些基本功能
最后看一下效果
到此,相信大家对“spring cloud oauth3整合JWT后获取用户信息不全怎么办”有了更深的了解,不妨来实际操作一番吧!这里是编程之家网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。