资讯专栏INFORMATION COLUMN

spring cloud feign实现远程调用服务传输文件

lmxdawn / 2415人阅读

摘要:实践案例包括两个项目,服务提供者项目名,调用服务项目名,主要给出两个服务之间的调用过程,文件上传功能不提供项目框架依赖一文件上传服务控制层文件上传控制文件上传文件上传开始文件上传结束,耗时文件上传失败业务层上传文件判

实践案例包括两个项目,服务提供者项目名:upload-service,调用服务项目名:upload-client,主要给出两个服务之间的调用过程,文件上传功能不提供

项目框架:spring-boot 2.0.1.RELEASE、spring-cloud Finchley.RELEASE

依赖:

</>复制代码

  1. io.github.openfeign.form
  2. feign-form
  3. 3.0.3
  4. io.github.openfeign.form
  5. feign-form-spring
  6. 3.0.3
  7. commons-fileupload
  8. commons-fileupload
  9. 1.3.3

一.文件上传服务upload-service
1.控制层

</>复制代码

  1. @Slf4j
  2. @CrossOrigin
  3. @RestController
  4. @RequestMapping("/ftp")
  5. @Api(description = "文件上传控制")
  6. public class FtpFileController {
  7. @Autowired
  8. private FtpFileService ftpFileService;
  9. /**
  10. * FTP文件上传
  11. *
  12. * @return
  13. */
  14. @PostMapping(value = "/uploadFile", consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
  15. public FtpApiResponse uploadFileFTP(@RequestPart(value = "file") MultipartFile file,
  16. @RequestParam("logId") String logId) {
  17. FtpApiResponse result = new FtpApiResponse<>();
  18. LogUtil.updateLogId(logId);
  19. try {
  20. log.info("文件上传开始!}");
  21. Long startTime = System.currentTimeMillis();
  22. FtpUploadResDTO resDTO = ftpFileService.uploadFile(file);
  23. result.setData(resDTO);
  24. result.setSuccess(true);
  25. result.setTimeInMillis(System.currentTimeMillis() - startTime);
  26. log.info("文件上传结束 resDTO:{},耗时:{}", resDTO, (System.currentTimeMillis() - startTime));
  27. } catch (ServiceException e){
  28. result.setSuccess(false);
  29. result.setErrorCode(ErrorMsgEnum.FILE_UPLOAD_EXCEPTION.getCode());
  30. result.setErrorMsg(ErrorMsgEnum.FILE_UPLOAD_EXCEPTION.getMsg());
  31. } catch (Exception e) {
  32. result.setSuccess(false);
  33. result.setErrorCode(ErrorMsgEnum.SYSTEM_ERROR.getCode());
  34. result.setErrorMsg(ErrorMsgEnum.SYSTEM_ERROR.getMsg());
  35. log.info("文件上传失败 Exception:{}", Throwables.getStackTraceAsString(e));
  36. }
  37. return result;
  38. }
  39. }

2.业务层

</>复制代码

  1. @Service
  2. @Slf4j
  3. public class FtpFileService {
  4. @Autowired
  5. private FtpFileManager ftpFileManager;
  6. /**
  7. * 上传文件
  8. *
  9. * @param file
  10. * @return
  11. */
  12. public FtpUploadResDTO uploadFile(MultipartFile file) {
  13. try {
  14. //判断上传文件是否为空
  15. if (null == file || file.isEmpty() || file.getSize() == 0) {
  16. log.info("传入的文件为空,file:{}", file);
  17. throw new ServiceException(ErrorMsgEnum.EMPTY_FILE);
  18. }
  19. //文件上传至ftp服务目录
  20. FtpFileRecordDO ftpFileRecordDO = ftpFileManager.fileUploadToFtp(file);
  21. if (null == ftpFileRecordDO) {
  22. log.info("文件上传至ftp服务目录异常");
  23. throw new ServiceException(ErrorMsgEnum.FILE_UPLOAD_TO_FTP_EXCEPTION);
  24. }
  25. return ftpFileManager.addFileRecord(ftpFileRecordDO);
  26. } catch (Exception e) {
  27. log.error("业务异常,case", e);
  28. throw new ServiceException(ErrorMsgEnum.SYSTEM_ERROR);
  29. }
  30. }
  31. }

3.服务写好后,需要把远程接口暴露出去

</>复制代码

  1. @FeignClient(value = "upload-service", configuration = UpDownFtpFacade.MultipartSupportConfig.class)
  2. public interface UpDownFtpFacade {
  3. /**
  4. * FTP上传文件
  5. *
  6. * @param file 文件
  7. * @param logId 日志id
  8. * @return
  9. */
  10. @PostMapping(value = "/ftp/uploadFile",consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
  11. FtpApiResponse uploadFileFTP(@RequestPart(value = "file") MultipartFile file,
  12. @RequestParam("logId") String logId);
  13. /**
  14. * 引用配置类MultipartSupportConfig.并且实例化
  15. */
  16. @Configuration
  17. class MultipartSupportConfig {
  18. @Bean
  19. public Encoder feignFormEncoder() {
  20. return new SpringFormEncoder();
  21. }
  22. }
  23. }

二.文件上传客户端upload-client

</>复制代码

  1. @Slf4j
  2. @Component
  3. public class FileManager {
  4. @Autowired
  5. private UpDownFtpFacade upDownFtpFacade;
  6. /**
  7. * 调用远程上传文件接口
  8. *
  9. * @param file 待上传的文件
  10. * @return 下载路径
  11. **/
  12. public FtpApiResponse requestFtpFacade(MultipartFile file) {
  13. try {
  14. DiskFileItem fileItem = (DiskFileItem) new DiskFileItemFactory().createItem("file",
  15. MediaType.ALL_VALUE, true, file.getOriginalFilename());
  16. InputStream input = file.getInputStream();
  17. OutputStream os = fileItem.getOutputStream();
  18. IOUtils.copy(input, os);
  19. MultipartFile multi = new CommonsMultipartFile(fileItem);
  20. FtpApiResponse response = upDownFtpFacade.uploadFileFTP(multi, LogUtil.getLogId());
  21. if (null == response || !response.getSuccess() || null == response.getData()) {
  22. throw new ManagerException(ErrorMsgEnum.FIlE_UPLOAD_FAILED);
  23. }
  24. return response;
  25. } catch (Exception e) {
  26. throw new ManagerException(ErrorMsgEnum.FIlE_UPLOAD_FAILED);
  27. }
  28. }
  29. }

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/76950.html

相关文章

  • SpringCloud(第 012 篇)微服务接入 Feign 负载均衡通过 FeignClient

    摘要:添加电影微服务启动类电影微服务接入进行客户端负载均衡,通过调用远程微服务。注解表示该电影微服务已经接入模块。 SpringCloud(第 012 篇)电影微服务接入 Feign 进行客户端负载均衡,通过 FeignClient 调用远程 Http 微服务 - 一、大致介绍 1、本章节主要介绍在 SpringCloud 生态圈中,使用一个类似于 Java HTTP 客户端的工具 Feig...

    Cobub 评论0 收藏0
  • 8、服务发现&服务消费者Feign

    摘要:公众号乐园的中提供了两个组件实现软负载均衡调用,分别是和。是基于和的客户端负载工具,它是基于实现的,它可以在客户端配置服务端列表,然后轮询请求以实现均衡负载。 公众号:java乐园 spring cloud的Netflix中提供了两个组件实现软负载均衡调用,分别是Ribbon和Feign。上一篇和大家一起学习了Ribbon。Ribbon :Spring Cloud Ribbon是基于H...

    lpjustdoit 评论0 收藏0
  • Spring Cloud Alibaba到底坑不坑?

    摘要:我没有能力去控制那些自媒体发布这些不实的内容,但是在我了解的范围内,还是尽力输出一些我的理解。 之前我发过一篇《说说我为什么看好Spring Cloud Alibaba》,然后这两天有网友给我转了这篇文章《坑爹项目spring-cloud-alibaba,我们也来一个》,问我的看法是怎么样的,聊天时候简单说了一下。今天在家休息,抽空整理一下内容,逐点说一下我的看法,主要还是觉得这篇文章...

    娣辩孩 评论0 收藏0
  • 解决spring cloud Feign远程调用服务,添加headers解决拦截器拦截问题

    摘要:使用做服务器时,经常会通过调用远程服务。有时候我们的远程服务可能做了某些权限验证。如果某没有,可能会被阻止调用。如果每个方法都手动设置,那未免太麻烦。可以通过一个切面,自动帮我们添加请求。 使用spring cloud 做saas服务器时,经常会通过Feign调用远程服务。有时候我们的远程服务可能做了某些权限验证。需要验证header或者token什么的。如果某没有token,可能会被...

    walterrwu 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<