SpringCloud Feign在远程调用中传输文件
2021-04-01 06:25
标签:client tar 处理 depend artifact 文件 enable 上传 依赖 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个包,用于编码的支持 6.2 给容器增加一个Bean,用于具体的编码支持 7. 总结 传文件主要盯住3样东西: POST请求方式, multipart/form-data媒体类型,远程调用的序列方案 SpringCloud Feign在远程调用中传输文件 标签:client tar 处理 depend artifact 文件 enable 上传 依赖 原文地址:https://www.cnblogs.com/wangxuejian/p/13549016.html
feign-form
feign-form-spring@Bean
public Encoder encoder(){
return new SpringFormEncoder();
}