美文网首页
Spring Cloud 分布式利用feignClient上传文

Spring Cloud 分布式利用feignClient上传文

作者: JackSpeed | 来源:发表于2018-01-15 18:20 被阅读0次

    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);

            在下新手,第一次写文章,大佬们勿喷,喜欢的大佬可以给个赞。

            最后附上大神的链接

            https://github.com/OpenFeign/feign-form

            http://blog.csdn.net/tony_lu229/article/details/73823757

    相关文章

      网友评论

          本文标题:Spring Cloud 分布式利用feignClient上传文

          本文链接:https://www.haomeiwen.com/subject/zxydoxtx.html