spring cloud feign Security消费端调用401

发布于 2022-09-07 04:20:24 字数 767 浏览 8 评论 0

在使用feign消费者调用提供者的时候 “返回认证” 报错
Full authentication is required to access this resource

详细错误
{"timestamp":1524018915085,"status":401,"error":"Unauthorized","message":"Full authentication is required to access this resource","path":"/activity-provider-service/user/add/12312321"}

直接访问提供者是可以成功的,通过消费者调用提供者服务就会报这个错误401

如果关闭掉security认证是可以访问成功的

clipboard.png

注册配置

clipboard.png

提供者

clipboard.png

调用者

clipboard.png

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

墨小沫ゞ 2022-09-14 04:20:24

解决办法添加拦截器

  1. 添加yml配置文件
security:
  oauth2:
    client:
      clientId: yourClientId
      clientSecret: yourClientSecret
      accessTokenUri: http://localhost:3000/oauth/token
      grant-type: client_credentials
      scope: service
    resource:
      user-info-uri: http://localhost:3000/me
  1. 编写Feign拦截器
@Configuration
public class FeignConfig {
    @Bean
    @ConfigurationProperties(prefix = "security.oauth2.client")
    public ClientCredentialsResourceDetails clientCredentialsResourceDetails() {
        return new ClientCredentialsResourceDetails();
    }

    @Bean
    public RequestInterceptor oauth2FeignRequestInterceptor(){
        return new OAuth2FeignRequestInterceptor(new DefaultOAuth2ClientContext(), clientCredentialsResourceDetails());
    }

    @Bean
    public OAuth2RestTemplate clientCredentialsRestTemplate() {
        return new OAuth2RestTemplate(clientCredentialsResourceDetails());
    }
}
随波逐流 2022-09-14 04:20:24

请问解决了吗

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文