1. 文件远程传输主要涉及3点: 请求方式, 媒体类型, 序列化与反序列化, 把握住了这3点,基本上就可以搞
2. 使用Feign传输,首先搭建起Feign的架子
2.1 引入spring-cloud-starter-eureka-server依赖,用于启动一个eureka注册中心
2.2 引入spring-cloud-starter-eureka依赖,用于开启向eureka注册中心注册自己
2.3 在调用远程服务的客户端引入spring-cloud-starter-feign, 用于使用feign
3. 既然是远程调用, 项目中就必须至少有2个服务,一个扮演客户端,一个扮演服务端,对于文件上传来说,可以将文件上传服务定为客户端,将文件的处理服务定为服务端.客户端接收到文件后调用服务端处理文件
3.1 创建一个eureka注册中心
3.2 创建一个客户端
3.3 创建一个服务端
4. 基础架构搭建好了以后,可以在2个服务中都搭建基础的上传服务接口了,测试上传文件没问题后,可以进行Feign的调用搭建
4.1 使用POST请求
4.2 指定接口接收的数据类型为multipart/form-data
4.3 使用MultipartFile类型接收文件
5. Feign的调用搭建
5.1 谁使用Feign就在谁的配置中开启支持注解@EnableFeignClients
5.2 创建Feign的基桩,在接口类上绑定要调用服务的服务ID,在接口方法上绑定要调用方法的请求路径,同时指定媒体类型
6. 此时重启2个服务,调用试试,发现报错,原因是编码问题,此时就是序列化和反序列化的问题,需要:
6.1 引入2个包,用于编码的支持
<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>
6.2 给容器增加一个Bean,用于具体的编码支持
@Bean
public Encoder encoder(){
return new SpringFormEncoder();
}
7. 总结
传文件主要盯住3样东西: POST请求方式, multipart/form-data媒体类型,远程调用的序列方案