Spring Boot+EasyExcel实现Excel文件

问题

最近遇到一个问题,Excel文件下载,本来是很简单的,结果下载后一直提示下面的信息

搞了两天,查了好多资料,都没解决,最后发现是参数问题,是参数问题

有问题版本

引用

pom文件引用对应jar包

复制代码
<dependency>
     <groupId>com.alibaba</groupId>
     <artifactId>easyexcel</artifactId>
     <version>3.1.1</version>
</dependency>

实现代码

复制代码
@GetMapping("/EasyExcel")
    public void EasyExcel(@Valid @RequestBody TestTaskInfoSceneQueryReqVo vo ,HttpServletResponse response) throws IOException {

        // 1. 生成数据
        List<User> users = new ArrayList<>();
        users.add(new User(1, "张三", 25, "zhangsan@test.com"));
        users.add(new User(2, "李四", 30, "lisi@test.com"));
        users.add(new User(3, "王五", 28, "wangwu@test.com"));

        response.addHeader("Content-Disposition", "attachment;filename=" + "huyuqiao.xlsx");
        response.setContentType("application/vnd.ms-excel;charset=gb2312");
        try {
//            从HttpServletResponse中获取OutputStream输出流
            ServletOutputStream outputStream = response.getOutputStream();
            /*
             * EasyExcel 有多个不同的read方法,适用于多种需求
             * 这里调用EasyExcel中通过OutputStream流方式输出Excel的write方法
             * 它会返回一个ExcelWriterBuilder类型的返回值
             * ExcelWriterBuilde中有一个doWrite方法,会输出数据到设置的Sheet中
             */
            EasyExcel.write(outputStream, User.class).sheet("测试数据").doWrite(users);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

问题说明

主要问题就是使用了@Valid @RequestBody TestTaskInfoSceneQueryReqVo vo 参数,这个会改变response流,影响下载结果。

可以改为下面的方式。

正常版本

引用

pom引用保持不变

实现代码

复制代码
@PostMapping("/EasyExcel")
    @Operation(summary = "测试任务下载接口")
    public void download(@RequestParam(required = false) Integer taskType,
                         @RequestParam(required = false) String station,
                         @RequestParam(required = false) @DateTimeFormat(pattern = "yyyy-MM-dd") Date startDate,
                         @RequestParam(required = false) @DateTimeFormat(pattern = "yyyy-MM-dd") Date endDate,HttpServletResponse response) throws IOException {
        // 1. 生成数据
        List<User> users = new ArrayList<>();
        users.add(new User(1, "张三", 25, "zhangsan@test.com"));
        users.add(new User(2, "李四", 30, "lisi@test.com"));
        users.add(new User(3, "王五", 28, "wangwu@test.com"));

        response.addHeader("Content-Disposition", "attachment;filename=" + "huyuqiao.xlsx");
        response.setContentType("application/vnd.ms-excel;charset=gb2312");
        try {
//            从HttpServletResponse中获取OutputStream输出流
            ServletOutputStream outputStream = response.getOutputStream();
            /*
             * EasyExcel 有多个不同的read方法,适用于多种需求
             * 这里调用EasyExcel中通过OutputStream流方式输出Excel的write方法
             * 它会返回一个ExcelWriterBuilder类型的返回值
             * ExcelWriterBuilde中有一个doWrite方法,会输出数据到设置的Sheet中
             */
            EasyExcel.write(outputStream, User.class).sheet("测试数据").doWrite(users);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

各位小伙伴有好的方法,可以评论区留言。

相关推荐
karry_k1 天前
MyBatis批量insert-select踩坑:useGeneratedKeys=true 可能让PostgreSQL返回大量插入结果
java·后端
karry_k1 天前
PostgreSQL 在 MyBatis 中执行正常 SQL 失效:一次 DELETE USING 踩坑记录
java·后端
SamDeepThinking1 天前
从源码到代码:MyBatis-Flex 与 MyBatis-Plus 的逐项对比
java·后端·程序员
她的男孩1 天前
Spring Boot 接 Flowable 工作流:用 3 个注解搭一个请假审批流程
java·后端·架构
荣码1 天前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
plainGeekDev1 天前
Gson → kotlinx.serialization
android·java·kotlin
小bo波2 天前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯2 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式