SpringCloud Feign MultipartFile 服务间调用 参数 MultipartFile
2020-07-16 04:51
1301 查看
大概需求是这样子的,微服务其中一个模块已经实现了文件的上传,其他微服务模块中,想直接通过feign的方式直接调用,但是问题出现了,一直报错, MultipartFile 参数接口报 no multipart boundary was found,一直找不到问题原因,很多说是需要使用@RequestPart,包括添加consumes = MediaType.MULTIPART_FORM_DATA_VALUE,都没有解决问题,最终使用如下方式,终于可以成功调用.
1:服务提供方:
注意需要添加 consumes = MediaType.MULTIPART_FORM_DATA_VALUE ,经测试发现,@RequestParam("file") MultipartFile file 或者 @RequestPart("file") MultipartFile file ,都可以成功调用,看来RequestPart并不是重点
2:服务调用方:
[code]@RequestMapping(value = "/faceApi/imageToByte", produces = MediaType.APPLICATION_JSON_UTF8_VALUE, consumes = MediaType.MULTIPART_FORM_DATA_VALUE) R imageToByte(@RequestPart(name = "file") MultipartFile file);
RequestPart应该也不是问题的重点(没有测试),但是需要produces = MediaType.APPLICATION_JSON_UTF8_VALUE, consumes = MediaType.MULTIPART_FORM_DATA_VALUE,两个必须都要有。
3:feign配置修改
[code]public class MultipartSupportConfig { @Autowired private ObjectFactory<HttpMessageConverters> messageConverters; @Bean public Encoder feignFormEncoder() { return new SpringFormEncoder(new SpringEncoder(messageConverters)); } }
引用见下方
另外在调用方需要添加如下依赖:
[code]<dependency> <groupId>io.github.openfeign.form</groupId> <artifactId>feign-form</artifactId> <version>3.8.0</version> </dependency> <dependency> <groupId>io.github.openfeign.form</groupId> <artifactId>feign-form-spring</artifactId> <version>3.8.0</version> </dependency>
看来feign的使用还是有很多需要注意的地方
相关文章推荐
- spring cloud feign 调用微服务转发不了request请求头和参数问题解决方案
- 使用Spring cloud Feign在后台服务之间调用传递Multipart无法传递的问题
- springcloud使用feign实现服务间条用,参数数据太大,无法调用成功解决方法
- Spring Cloud Feign 声明式服务调用
- spring cloud feign实现远程调用服务传输文件的方法
- SpringCloud之服务调用(feign)
- SpringCloud 通过Feign 调用其他服务下载文件
- 使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务
- springcloud 服务feign调用问题
- Spring Cloud微服务(7)之Feign服务之间调用
- SpringCloud 第二节 两种服务调用方式(ribbon和feign)
- 使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务的方法(推荐)
- Spring Cloud中声明式服务调用Feign (11)
- 使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务
- Springcloud微服务调用ribbon与feign
- SpringCloud微服务调用方式之Ribbon和Feign方式
- SpringCloud之服务提供与调用(Ribbon,Feign)
- Spring Cloud ZooKeeper集成Feign的坑2,服务调用了一次后第二次调用就变成了500,错误:Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is com.n
- Spring Cloud Feign 声明式服务调用
- spring cloud feign 调用服务注意问题