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

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

相关推荐
二哈赛车手13 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
栗子~~14 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
程序员敲代码吗14 小时前
Go语言中Channel的实现与内存通信机制详解
excel
YDS82914 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
未若君雅裁15 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
AI人工智能+电脑小能手15 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
阿维的博客日记16 小时前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI16 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
辰海Coding17 小时前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构
小小编程路17 小时前
C++ 多线程与并发
java·jvm·c++