自定义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;
}

<!-- more -->

但是有时候默认的并不满足全部的场景,我们需要自定义来进行配置,可以通过@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)

参考文献


bug生产者
20 声望0 粉丝