SpringCloud Feign在远程调用中传输文件


	SpringCloud Feign在远程调用中传输文件
[编程语言教程]

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媒体类型,远程调用的序列方案

SpringCloud Feign在远程调用中传输文件

原文地址:https://www.cnblogs.com/wangxuejian/p/13549016.html

hmoban主题是根据ripro二开的主题,极致后台体验,无插件,集成会员系统
自学咖网 » SpringCloud Feign在远程调用中传输文件