时间:2021-05-20
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,用于具体的编码支持
@Beanpublic Encoder encoder(){ return new SpringFormEncoder();}7. 总结
传文件主要盯住3样东西: POST请求方式, multipart/form-data媒体类型,远程调用的序列方案
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在SpringCloud的Feign组件中并不支持文件的传输,会出现这样的错误提示:feign.codec.EncodeException:class[Lorg
在SpringCloud封装的Feign中并不直接支持传文件,但可以通过引入Feign的扩展包来实现,本来就来具体说说如何实现。服务提供方(接收文件)服务提供方
前言在SpringCloud中,Feign和Ribbon在整合了Hystrix后,可能会出现首次调用失败的问题,要如何解决该问题呢?造成该问题的原因Hystri
使用微服务的时候往往服务之间调用比较麻烦,springcloud提供了Feign接口调用,RestTemplate调用的方式这里我探讨下RestTemplate
最近经常有人问SpringCloudFeign如何上传文件。有团队的新成员,也有其他公司的兄弟。本文简单做个总结——早期的SpringCloud中,Feign本