只会一点java

java持续学习者,每月一篇博客。罗列出技术栈,慢慢完善,持续学习,总有一天,你会追上甚至超越曾经的大神。
  博客园  :: 首页  :: 联系 :: 订阅 订阅  :: 管理

1.问题梳理:

异常:org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'POST' not supported

很明显是最终feign执行http请求时把这个方法认定为POST,但feign client中又定义了RequestMethod.GET 或 @GetMapping,冲突导致报错

那么为什么feign会认为这个方法是post呢?

源码追踪:

1.我们从feignClient注解作为入口来看:

2.按照spring cloud一贯风格,我们打开FeignAutoConfiguration这个类看配置逻辑:

 

看上图红框内的标注:这个类在不存在ILoadBalancer时才触发,我们项目开启了Ribbon,所以肯定存在,再看注释:载入负载均衡ribbon clients需要走FeignRibbonClientAutoConfiguration这个类配置。go~

如上图,看红框注释:按照导入从上往下的顺序:HttpClientFeignLoadBalancedConfiguration>OkHttpFeignLoadBalancedConfiguration>DefaultFeignLoadBalancedConfiguration,对应的底层http工具:httpclient>okhttp>HttpURLConnection

根据http协议定义是支持@RequestBody+ RequestMethod.GET的,那么具体就得看工具包实现的不同的,查看源码发现okhttpHttpURLConnection都不支持(报错),只有httpclient支持。(默认走HttpURLConnection会报错

我们知道只有httpclient支持@RequestBody+ RequestMethod.GET,所以我们必须满足条件走HttpClientFeignLoadBalancedConfiguration才行,看下源码:

可见,满足类路径下存在ApacheHttpClient类即可。我们再pom中添加:

<dependency>
     <groupId>io.github.openfeign</groupId>
     <artifactId>feign-httpclient</artifactId>
 </dependency>

最终载入了feign-httpclient-9.5.0.jar包,打开看里面就一个ApacheHttpClient.class,点进去看其实就是一个httpclient。

 

所以pom中引入feign-httpclient--》类路径下存在ApacheHttpClient.class--》走HttpClientFeignLoadBalancedConfiguration--》请求时走HttpClient--》支持@RequestBody+ RequestMethod.GET

2.解决方式:

 pom中引入

<dependency>
     <groupId>io.github.openfeign</groupId>
     <artifactId>feign-httpclient</artifactId>
 </dependency>

maven更新后查看项目中是否存在了feign-httpclient-9.5.0.jar包。