Feign文件上传

Feign文件上传

1. 在自己的文件上传服务中引入feign 提供的依赖
        <dependency>
           <groupId>io.github.openfeign.form</groupId>
            <artifactId>feign-form</artifactId>
            <version>3.0.3</version>
        </dependency>
        <dependency>
            <groupId>io.github.openfeign.form</groupId>
            <artifactId>feign-form-spring</artifactId>
            <version>3.0.3</version>
        </dependency>
2.编写文件上传controller
@RestController
@RequestMapping
@Slf4j
public class StorageController {

    @PostMapping(value = "/upload", consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
    @ResponseBody
    public String upload(@RequestParam("file") MultipartFile file) {

        return "";
    }
}
3.编写供其他服务调用的feignClient

需要自定义配置feign 的encoder来解码multipartFile提交

在FeignClientsConfiguration第74行可知feign默认的encoder配置是 SpringEncoder

   @Bean
	@ConditionalOnMissingBean
	public Encoder feignEncoder() {
		return new SpringEncoder(this.messageConverters);
	}

(1).第一种配置方式
@FeignClient(value = "ResourceService",
        path = "/resource/",
        configuration = ResourceClient.MultipartConfig.class)
public interface ResourceClient {
    @PostMapping(value = "/upload", consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
    Resource upload(@RequestPart("file") MultipartFile file);

    class MultipartConfig {
        @Bean
        public Encoder feignFormEncoder() {
            return new SpringFormEncoder();
        }
    }
}

使用@FeignClient的configuration来配置当前client的encoder
注意不要在此配置类上添加@configruation,否则会影响全局的encoder配置

这样的话只会修改当前Client的默认的encoder

(2).第二种配置方式

直接修改全局的Encoder

@FeignClient(value = "ResourceService",
        path = "/resource/")
public interface ResourceClient {
    @PostMapping(value = "/upload", consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
    Resource upload(@RequestPart("file") MultipartFile file);
}
@Configruation
public  class MultipartConfig {
        @Bean
        public Encoder feignFormEncoder(ObjectFactory<HttpMessageConverters> messageConverters) {
            return new SpringFormEncoder(new SpringEncoder(messageConverters));
        }
}

如果直接将默认的全局SpringEncoder替换为SpringFormEncoder的话,普通的请求可能会报xxx is not a type supported by this encoder 的异常。

查看SpringFormEncoder的源码可知SpringFormEncoder.encode()方法判断bodyType是不是multipartFile,不是的话就直接调用默认的Encode处理
SpringFormEncoder的encode方法
默认的Encoder.Default.encode()只会判断bodyType是否是 String还是byte[] 否则就会报xxx is not a type supported by this encoder 的异常。
Encoder.Default.encode
所以在将全局的Encoder替换为SpringFormEncoder时将SpringFormEncoder的默认的encoder设置为SpringEncoder

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值