苍穹外卖Day12笔记

苍穹外卖笔记 Day12

0. 前言

  • 日期:2026.04.25
  • 核心内容:Apache POI、Maven 坐标、Excel 导出、HttpServletResponse、类加载器读取资源文件
  • 难度:中等
  • 应用场景:运营数据报表导出、Excel 模板下载、订单导出、菜品导出

一、Apache POI

1. 基本介绍

  • Apache POI 是 Java 操作 Excel、Word、PowerPoint 的开源工具库
  • 苍穹外卖主要用于:Excel 报表导出(订单导出、菜品销量导出、运营报表导出)
  • 支持两种格式:
    • xls:Excel 2003 及以前版
    • xlsx:Excel 2007 及以后版(现在主流)

2. 核心作用

  • 创建 Excel 文件
  • 读取 Excel 文件
  • 写入单元格数据
  • 设置样式、字体、表头
  • 通过浏览器下载导出

二、Maven 坐标(必须导入)

1. poi(处理 xls)

xml 复制代码
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>4.1.2</version>
</dependency>

2. poi-ooxml(处理 xlsx,必须)

xml 复制代码
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>4.1.2</version>
</dependency>

三、HttpServletResponse 下载 Excel

1. 作用

  • 通过 HTTP 响应,把生成的 Excel 文件返回给浏览器
  • 实现文件下载功能

2. 苍穹外卖固定写法

java 复制代码
// 设置响应头
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.setCharacterEncoding("utf-8");
// 设置下载文件名
response.setHeader("Content-Disposition", "attachment;filename=data.xlsx");

3. 输出 Excel

java 复制代码
// workbook 为 POI 创建的 Excel 对象
workbook.write(response.getOutputStream());
workbook.close();

四、类加载器读取资源文件

1. 方法

java 复制代码
this.getClass().getClassLoader().getResourceAsStream("文件名.xlsx");

2. 作用

  • 读取 resources 目录下的 Excel 模板文件
  • 苍穹外卖场景:下载模板、使用固定模板导出

3. 使用示例

java 复制代码
InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("template.xlsx");
XSSFWorkbook workbook = new XSSFWorkbook(inputStream);

五、Day12 核心流程(Excel 导出)

  1. 导入 poi、poi-ooxml Maven 坐标
  2. 读取 resources 下的 Excel 模板(类加载器)
  3. 使用 POI 向 Excel 写入数据
  4. 通过 HttpServletResponse 输出文件
  5. 浏览器自动下载 Excel 文件

六、总结

  1. Apache POI:Java 操作 Excel 的核心工具
  2. poi + poi-ooxml:导出 xlsx 必须的两个依赖
  3. HttpServletResponse:负责浏览器下载
  4. getClassLoader().getResourceAsStream():读取 resources 下的模板文件
  5. 苍穹外卖用途:订单导出、菜品导出、运营报表、Excel 模板下载
相关推荐
闪闪发亮的小星星3 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq3 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波3 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.3 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余3 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.3 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央3 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器3 天前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记
影寂ldy3 天前
WinForm PictureBox控件 + ImageList组件 完整笔记
开发语言·笔记·swift