自定义Feign的配置
Feign的默认配置类是FeignClientsConfiguration,其内部定义了Feign默认使用的编码器、解码器、契约、重试机制等
@Bean
@ConditionalOnMissingBean
public Decoder feignDecoder() {
// 解码器,将字节数组反序列化为方法返回值类型的对象,默认只支持反序列化为String和byte[]
// SpringDecoder使用消息解析器可以支持任意类型
return new OptionalDecoder(
new ResponseEntityDecoder(new SpringDecoder(this.messageConverters)));
}
@Bean
@ConditionalOnMissingBean
@ConditionalOnMissingClass("org.springframework.data.domain.Pageable")
public Encoder feignEncoder() {
// 编码器,将请求体对应的方法参数序列化为字节数组,默认的只支持参数为String和byte[]
// SpringEncoder可以将任意方法参数序列化
return new SpringEncoder(this.messageConverters);
}
@Bean
@ConditionalOnMissingBean
public Contract feignContract(ConversionService feignConversionService) {
// Contract的作用是解析方法上的注解和参数,构建Http请求需要用到的基本参数
// SpringMvcContract使得Feign能够识别SpringMvc的注解
return new SpringMvcContract(this.parameterProcessors, feignConversionService);
}
@Bean
@ConditionalOnMissingBean
public Retryer feignRetryer() {
return Retryer.NEVER_RETRY;
}
但是有时候默认的并不满足全部的场景,我们需要自定义来进行配置,可以通过@FeignClient注解中的configuration属性来配置自定义的feign配置类,其优先级高于FeignClientsConfiguration
自定义Feign
@Configuration
public class FeignConfiguration {
/**
* 使用feign的原生注解
*
* @author zhanghe
* @return feign的使用形式
*/
@Bean
public Contract feignContract() {
log.debug("原生feign [bean注册]");
return new feign.Contract.Default();
}
/**
* 公共错误回调
* @return 错误回调
*/
@Bean
public FallBackImpl fallBackImpl() {
return new FallBackImpl();
}
}
如果该配置类为该项目下所有feign共用的,那么该类需要在@componentScan扫描下,这样就可以覆盖原本的默认配置,如果不希望该配置共用,只是个别feign使用,则该类不可以在@componentScan扫描下,而是要在所需要的feign中单独进行配置@FeignClient(configuration=FeignConfiguration.class)
参考文献