2023年4月21日-关于远程feign调用实现文件上传下载

一、客户需求:做一个查询程序,客户提供一个excel模板,将查询结果保存到excel模板中,上传到文件服务,供客户下载使用。

二、代码实现

// 服务A,文件上传
@ApiOperation("上传文件-demo")
@PostMapping(value = "/uploadDemo/{busType}/{billId}")
public ResBean uploadFile(@PathVariable("busType") String busType,
                                          @PathVariable("billId") String billId,
                                          @RequestParam(value = "file")  MultipartFile file
                                         )  {
  
  /**
  ......省略上传逻辑
  */

  return null;
}
// 服务B,feign客户端
package com.xxxx.remote;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.http.MediaType;
import org.springframework.stereotype.Repository;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;
@Repository
@FeignClient(name = "xxxxx")
public interface FeignClient {
    @PostMapping(value = "/xxxx/xxxx/{busType}/{billId}"
            , produces = {MediaType.APPLICATION_JSON_UTF8_VALUE}
            , consumes = MediaType.MULTIPART_FORM_DATA_VALUE
    )
    ResBean uploadFile(@PathVariable("busType") String busType,
                                       @PathVariable("billId") String billId,
                                       @RequestPart("file") MultipartFile file

    );
}
// 服务B,业务层
public ResBean optexcel() throws IOException {
        List<UserEntity> dataList = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            UserEntity userEntity = new UserEntity();
            userEntity.setName("张三" + i);
            userEntity.setAge(20 + i);
            userEntity.setTime(new Date(System.currentTimeMillis() + i));
            dataList.add(userEntity);
        }
        //生成excel文档
        Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams("用户","用户信息"),
                UserEntity.class, dataList);
        MultipartFile file = workbookToCommonsMultipartFile(workbook, "用户.xls");

        ResBean resbean = this.FeignClient.uploadFile(
               "xxxxxx",
               "111222333",
                file
                );
        return resbean;
    }
    public static MultipartFile workbookToCommonsMultipartFile(Workbook workbook, String fileName) {
        FileItemFactory factory = new DiskFileItemFactory(16, null);
        FileItem fileItem = factory.createItem("file", "text/plain", true, fileName);
        try {
            OutputStream os = fileItem.getOutputStream();
            workbook.write(os);
            os.close();
            MultipartFile multipartFile = new CommonsMultipartFile(fileItem);
            return multipartFile;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }
总结:
  坑1:不加如下注解,
  produces = {MediaType.APPLICATION_JSON_UTF8_VALUE}
  consumes = MediaType.MULTIPART_FORM_DATA_VALUE
  报错信息:
  Current request is  not a multipart request
  坑2:不使用@RequestPart
  报错信息:the request was rejected because no multipart boundary was found
  坑3:workbookToCommonsMultipartFile中factory.createItem方法中,第一参数,要和@RequestPart注解中value值一致
  不一致报错信息:
  Required request part 'file' is not present
  坑4:上传到服务器的excel重新下载后,打开时,会提示文件损坏
  这时候需要给excel做一下授信,授信成功,就可以正常打开了。
  授信操作参考:https://jingyan.baidu.com/article/c85b7a64a7337d413aac9555.html

原文链接:https://www.cnblogs.com/public-communion/p/17338082.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:2023年4月21日-关于远程feign调用实现文件上传下载 - Python技术站

(0)
上一篇 2023年4月22日
下一篇 2023年4月22日

相关文章

  • SpringBoot整合Elasticsearch7.2.0的实现方法

    下面我将给出SpringBoot整合Elasticsearch7.2.0的实现方法的完整攻略,具体流程如下: 一、引入依赖 首先,在pom.xml文件中引入以下依赖: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spr…

    Java 2023年5月20日
    00
  • Mybatis环境搭建和使用实例代码

    下面我将为你详细讲解 Mybatis 环境搭建和使用实例代码的完整攻略。 环境搭建 1. 下载和配置 Mybatis Mybatis 官网提供了下载链接,可以去官网 https://mybatis.org/mybatis-3/zh/getting-started.html 下载最新版本的 Mybatis。 下载完成后,将 Mybatis 的 jar 包拷贝到…

    Java 2023年5月20日
    00
  • 图解Java经典算法冒泡选择插入希尔排序的原理与实现

    图解Java经典算法冒泡选择插入希尔排序的原理与实现 什么是排序算法? 排序算法是计算机科学中的一类基本算法,它将一个乱序的数据序列按照一定的规则重新排列,使得排序后的序列满足特定的要求。 常见的排序方法包括冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序等。 冒泡排序的原理和实现 冒泡排序是一种简单的排序算法,其基本思想是从小到大依次比较相邻的两…

    Java 2023年5月19日
    00
  • java中创建写入文件的6种方式详解与源码实例

    Java中创建和写入文件的6种方式详解与源码实例 在Java中,我们可以使用多种方式来创建和写入文件。下面将详细介绍Java中创建和写入文件的6种方式,并提供代码示例。 1. 通过FileOutputStream写入文件 import java.io.*; public class FileOutputStreamExample { public stati…

    Java 2023年5月20日
    00
  • springboot用户数据修改的详细实现

    SpringBoot用户数据修改的详细实现 在SpringBoot中,我们可以使用Spring Data JPA来实现用户数据的修改。以下是一个详细的实现攻略: 1. 添加依赖 在pom.xml文件中添加以下依赖: <dependency> <groupId>org.springframework.boot</groupId&g…

    Java 2023年5月15日
    00
  • Java连接数据库,及增删改查的示例

    下面是“Java连接数据库,及增删改查的示例”的完整攻略。 1. 连接数据库 Java连接数据库通常需要使用JDBC API,需要先下载并安装相应的JDBC驱动。一般情况下,不同的数据库使用的JDBC驱动是不同的,我们需要选择对应的JDBC驱动。以MySQL为例,我们可以使用以下步骤来连接数据库: 1.下载MySQL官方提供的JDBC驱动,例如mysql-c…

    Java 2023年5月19日
    00
  • Spring中循环依赖的解决方法详析

    Spring中循环依赖的解决方法详析 在 Spring 中,当两个或更多的 Bean 之间存在循环依赖时,会导致容器的初始化过程无法完成,抛出 BeanCurrentlyInCreationException 异常。Spring 提供了三种方式来解决此问题。 1. 通过setter方法注入 在循环依赖的两个或多个 Bean 中,其中一个使用 setter 方…

    Java 2023年5月19日
    00
  • 用3个实例从原理到实战讲清楚Log4j史诗级漏洞

    下面我将通过三个实例,从原理到实战,讲解清楚Log4j史诗级漏洞的完整攻略。 什么是 Log4j Log4j是一个流行的Java日志框架,它是Apache的一个子项目。Log4j可以帮助Java开发人员以更优美的方式记录日志,便于排错和性能调优。 Log4j的漏洞 但是,在2021年底,Log4j被发现有史以来最严重的漏洞,被称为 Log4Shell ,它属…

    Java 2023年6月15日
    00
合作推广
合作推广
分享本页
返回顶部