Spring Cloud 分布式利用feignClient上传文件问题
最近项目代码重构,利用Spring cloud 分布式五大神兽实现,做到文件上传模块时卡壳了两天!足足两天!想想就是心累,毕竟新手遇到问题处理能力差了点。直接上代码,老夫敲代码就是一梭子!
把依赖先添加上:
1.接收文件Service代码
2.ribbon-server 模块代码
重点是FeignMultipartConfig,这个配置网上有很多,我也参考了很多为大神的写法,不知道是我配置出问题了还是哪里出错了,各种方式都试过了,结果发现不够完美,其中用了@RequestLine("POST")文件是能够传到service的,但是有字符串参数(Json字符串)没法用post直接传过去,最终还是放弃了这个方案。从刚开始的请求不到接收文件的service端,到service能接到文件,费尽周折。先附上从大神出捞来的代码截图。
这个写法是能够把文件传过去,json字符串也能传到service,当时心里一阵窃喜,总算搞定了。于是乎代码上传打卡下班,第二天上班同事说,带有RequestBody的请求从ribbon-server请求到其他service都不行了!说是把我这个配置类取消就可以!当时一个尴尬啊。然后又默默的看源码,继续在某度、github、google上搜,发现最终版其实跟现在差不多,最终版本。
问题终于搞定了,发现自身问题还是很明显的,源码看的少,翻看源码即可发现,new SpringFormEncoder(new SpringEncoder(messageConverters))与new SpringFormEncoder()的区别。下面是源码
SpringFormEncoder源码
SpringEncoder源码
我大概理解就是,如果请求是不带MultipartFile,则直接返回SpringEncoder处理方式,带有MultipartFile则MultipartFile file = (MultipartFile) object;
Map data = Collections.singletonMap(file.getName(), object);
new SpringMultipartEncodedDataProcessor().process(data, template);
在下新手,第一次写文章,大佬们勿喷,喜欢的大佬可以给个赞。
最后附上大神的链接
网友评论