苍穹外卖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 模板下载
相关推荐
穗余5 分钟前
2026 AI x Web3 School共学营笔记-Day10-Women Builders in AI × Web3
人工智能·笔记·web3
暴躁小师兄数据学院9 分钟前
【AI大数据工程师特训笔记】第10讲:数据库用户、权限管理、数据库约束
大数据·数据库·笔记·sql·postgresql
暴躁小师兄数据学院1 小时前
【AI大模型应用开发工程师特训笔记】第04讲(第9章):文件目录操作
人工智能·笔记·python
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.05.27 题目:3121. 统计特殊字母的数量 II
笔记·算法·leetcode
疯狂打码的少年1 小时前
CISC vs RISC 对比
jvm·笔记
garmin Chen1 小时前
LeetcodeHot100打卡(14、合并空间,15、轮转数组,16、除了自身以外数组乘积,17.缺失的第一个整数)
java·笔记·学习·算法
wan55cn@126.com1 小时前
调试协作之歌
人工智能·笔记·微信
就叫飞六吧2 小时前
cookie的SameSite属性
笔记
ん贤2 小时前
Higress 详细笔记
笔记·云原生·higress
不羁的木木2 小时前
ArkWeb实战学习笔记04-JavaScript与Native通信
笔记·学习·harmonyos