苍穹外卖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 模板下载
相关推荐
hnult2 小时前
AI 在线考试全流程 :考试云七大核心 AI 功能深度解读
人工智能·笔记·重构·课程设计
普通young man3 小时前
vim常用编辑和视图(个人笔记)
笔记·编辑器·vim
sheeta19983 小时前
LeetCode 每日一题笔记 日期:2026.05.07 题目:3660. 找到所有可以到达的最大值
笔记·算法·leetcode
wangcheng3033 小时前
智算集群:你身边的智能算力新形态
笔记
kels88994 小时前
2026 年黄金实时价格数据 API 接口实测推荐
开发语言·笔记·python·金融·区块链
深蓝海拓4 小时前
用HSL颜色系统改造qdarkstyle样式表库
前端·笔记·python·qt·学习
中屹指纹浏览器7 小时前
2026普通浏览器与指纹浏览器底层差异详解,从原理架构到风控实战全维度剖析
经验分享·笔记
05候补工程师8 小时前
【408考研·OS】核心考点:中断分类、线程模型 (KLT/ULT) 与调度算法方法论总结
经验分享·笔记·考研·算法
ouliten8 小时前
[Triton笔记2]自动调优和共享内存
笔记