Java实现生成并下载Excel文件

本文介绍了如何在Java SpringBoot项目中,借助Apache POI库,根据前端请求从MySQL数据库获取数据并生成Excel文件,然后提供下载。文章详细讲解了后端接口的实现,包括控制层、业务逻辑层、数据持久层和实体类的代码示例。
摘要由CSDN通过智能技术生成

前言

做OA管理系统的时候,刚好有个需求:根据指定条件从MYSQL数据库获取列表,将列表生成Excel,并直接下载到本地

工具及插件

项目框架:SpringBoot + Mybatis + MySQL

第三方插件:Lombok

项目引用的是Apache poi生成EXCEL文件

最终导出结果会是这样的,如图:

一、前端调用

$("#button").click(function(){
    let params = let params =  "?city = '北京'&street = '西长安街'";
    window.location.href = "http://127.0.0.1:8080/excel/exportExcel" + params;
});

二、后端接口

代码中引用了lombok插件,直接使用注解的方式

Result类 是我自己封装的一个返回结果类

Maven

<!-- poi -->
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi</artifactId>
	<version>3.17</version>
</dependency>
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi-ooxml</artifactId>
	<version>3.17</version>
</dependency>
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi-scratchpad</artifactId>
	<version>3.17</version>
</dependency>

控制层Controller

import javax.servlet.http.HttpServletResponse;
import java.util.Map;

@RestController
@RequestMapping("excel")
public class ExcelController {

	@Autowired
    private ExcelService excelService;

	/**
	 * 批量导出
	 */
	@RequestMap
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学弟不想努力了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值