springcloud feign 实现文件上传 |
您所在的位置:网站首页 › feignclient传输文件流 › springcloud feign 实现文件上传 |
文章目录
项目版本背景feign-form
文件上传入门步骤
项目版本
1、jdk:1.8 2、springboot 2.1.6.RELEASE ,springcloud Greenwich.SR6 背景在早期的 Spring Cloud 中,Feign本身是没有上传文件功能的,要想实现文件上传功能, Feign 早先不支持文件上传,后来虽支持但仍有缺陷,需要一次性完整地读到内存在编码发送。Feign官方提供了子项目feign-form(https://github.com/openFeign/feign-form)。 feign-formfeign-form 扩展依赖于 OpenFeign ,feign-form版本: feign-form 3.5.0 之前的所有 版本都适用于 OpenFeign 9.* 版本;从 feign-form 3.5.0 版本开始,该模块适用于 OpenFeign 10.1.0 及更高版本。 提示:feign-form没有向后兼容性,也没有任何保证 3.5.0 之后的 feign-form 版本可以与 10.* 之前的 OpenFeign 一起使用。 OpenFeign 在第 10 版中进行了重构,因此最好的方法是 使用最新的 OpenFeign 和 feign-form 版本。 文件上传使用的项目都是我之前学习的模块: springcloud 入门(1) eureka注册中心 springcloud 入门 之网关 springcloud gateway 感兴趣的可以看一看。 入门步骤其实使用起来也很简单: 1、在消费端引入feign-form依赖 这里是在消费端eureka-consumer引入 io.github.openfeign.form feign-form-spring 3.8.0 io.github.openfeign.form feign-form 3.8.02、在消费端Feign client配置文件中 注入SpringFormEncoder FeignClientConfig.java @Configuration public class FeignClientConfig { /** * feign 日志打印 * @return */ @Bean public Logger.Level getFeignLoggerLevel() { return feign.Logger.Level.FULL; } @Bean @Primary @Scope("prototype") public Encoder multipartFormEncoder() { return new SpringFormEncoder(); } }3、在消费端及生产端使用 生产端: 使用很简单,只需要在对外提供的接口上限制接受的媒体类型 注意:文件接受参数注解用的是@RequestPart @RequestMapping("/user") @RestController public class UserController { @Autowired private UserService userService; @PostMapping(value = "uploadFile" , consumes = MediaType.MULTIPART_FORM_DATA_VALUE) String uploadFile(@RequestPart("file") MultipartFile multipartFile){ return userService.uploadFile(multipartFile); } }这里是把文件名打印出来 @Service public class UserServiceImpl implements UserService { @Override public String uploadFile(MultipartFile multipartFile) { final String originalFilename = multipartFile.getOriginalFilename(); return originalFilename; } }消费端: 消费端在调用生产端的接口上也要限制媒体类型,并且使用FeignClientConfig作为配置文件 UserProviderClientService.java @FeignClient(name = "CLOUD-GATEWAY" , path = "/user-providers/user" ,fallbackFactory = UserProviderServiceFallbackFactory.class,configuration = FeignClientConfig.class) public interface UserProviderClientService { @PostMapping(value= "uploadFile" , consumes = MediaType.MULTIPART_FORM_DATA_VALUE) String uploadFile(@RequestPart("file") MultipartFile multipartFile); }FeignController.java @RequestMapping("/consumer/feign") @RestController public class FeignController { @Autowired private UserProviderClientService userProviderClientService; @PostMapping(value = "uploadFile" , consumes = MediaType.MULTIPART_FORM_DATA_VALUE) String uploadFile(@RequestPart("file") MultipartFile multipartFile){ return userProviderClientService.uploadFile(multipartFile); } }4、测试 使用postman测试 至此,feign上传文件功能就完成。 有关feign的学习可以参考springcloud 入门(3) 声明式调用 Feign 学习更多关于springcloud的可以关注我的 springcloud 专栏 GitHub地址: https://github.com/ArronSun/micro-services-practice.git 参考: 《重新定义springcloud 实战》 能力一般,水平有限,如有错误,请多指出。 如果对你有用点个关注给个赞呗 |
今日新闻 |
点击排行 |
|
推荐新闻 |
图片新闻 |
|
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭 |