文章目录
- 自定义Feign的配置
- 自定义Feign
自定义Feign的配置
Feign的默认配置类是FeignClientsConfiguration,其内部定义了Feign默认使用的编码器、解码器、契约、重试机制等
java">@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
java">@Configuration
public class FeignConfiguration {/*** 使用feign的原生注解* * @author zhanghe* @return feign的使用形式*/@Beanpublic Contract feignContract() {log.debug("原生feign [bean注册]");return new feign.Contract.Default();}/*** 公共错误回调* @return 错误回调*/@Beanpublic FallBackImpl fallBackImpl() {return new FallBackImpl();}
}
如果该配置类为该项目下所有feign共用的,那么该类需要在@componentScan扫描下,这样就可以覆盖原本的默认配置,如果不希望该配置共用,只是个别feign使用,则该类不可以在@componentScan扫描下,而是要在所需要的feign中单独进行配置@FeignClient(configuration=FeignConfiguration.class)
参考文献
- 自定义Feign的配置