【问题解决】apache.poi 3.1.4版本升级到 5.2.3,导出文件报错版本无法解析

embedded/2024/10/19 9:44:17/

【问题解决】apache.poi 3.1.4版本升级到 5.2.3,导出文件报错无法解析

3.1.4版本代码:

    /*** 创建workbook* @param inp* @return* @throws Exception*/public Workbook createworkbook(InputStream inp) throws Exception {if (!inp.markSupported()) {inp = new PushbackInputStream(inp, 8);}if (POIFSFileSystem.hasPOIFSHeader(inp)) {return new HSSFWorkbook(inp);}if (POIXMLDocument.hasOOXMLHeader(inp)) {return new XSSFWorkbook(OPCPackage.open(inp));}throw new IllegalArgumentException("你的excel版本目前poi解析不了");}

在POI 4.0.x版本过后,POIFSFileSystem.hasPOIFSHeader()POIXMLDocument.hasOOXMLHeader()便弃用了,所以我们需要找到新版本的替代方法,为此查阅了不少资料。

这里有两个方案可以参考一下:

  1. java">public Workbook createworkbook(InputStream inp) throws Exception {try (PushbackInputStream pushbackInputStream = new PushbackInputStream(inp, 8)) {byte[] header = new byte[8];int read = pushbackInputStream.read(header);pushbackInputStream.unread(header, 0, read);if (POIUtils.hasOOXMLHeader(header)) {return new XSSFWorkbook(OPCPackage.open(pushbackInputStream));} else if (POIUtils.hasPOIFSHeader(header)) {return new HSSFWorkbook(pushbackInputStream);} else {throw new IllegalArgumentException("不支持的 Excel 格式");}}
    }
    

    主要变更如下:

    1. 使用 POIUtils.hasOOXMLHeader(header) 方法替换 POIDataSamples.getSpreadSheetInstance().acceptsFile(header) 方法。这个方法可以检测 XSSF 格式(OOXML)。
    2. 使用 POIUtils.hasPOIFSHeader(header) 方法检测 HSSF 格式(97-2003 Excel)。
    3. 如果以上两种方式都无法识别,则抛出一个自定义的异常。

    这种方式可以有效地替换之前的代码,并适用于 Apache POI 5.2.3 版本。

    需要注意的是,需要引入 org.apache.poi.util.POIUtils 类,这个类是 Apache POI 5.2.3 中新增的一个工具类,提供了一些常用的工具方法。

  2. java">public Workbook createworkbook(InputStream inp) throws Exception {try (PushbackInputStream pushbackInputStream = new PushbackInputStream(inp, 8)) {byte[] header = new byte[8];int read = pushbackInputStream.read(header);pushbackInputStream.unread(header, 0, read);if (isXSSF(header)) {return new XSSFWorkbook(OPCPackage.open(pushbackInputStream));} else if (isHSSF(header)) {return new HSSFWorkbook(pushbackInputStream);} else {throw new IllegalArgumentException("不支持的 Excel 格式");}}
    }private boolean isXSSF(byte[] header) {// 检查 OOXML 文件头标识return header[0] == (byte) 0x50 && header[1] == (byte) 0x4B && header[2] == (byte) 0x03 && header[3] == (byte) 0x04;
    }private boolean isHSSF(byte[] header) {// 检查 POIFS 文件头标识return header[0] == (byte) 0xD0 && header[1] == (byte) 0xCF && header[2] == (byte) 0x11 && header[3] == (byte) 0xE0;
    }	
    

    这个替代方案中,自己实现了 isXSSFisHSSF 方法来检测 OOXML 和 POIFS 文件头标识,达到了同样的效果。

踩坑啊!


http://www.ppmy.cn/embedded/94603.html

相关文章

前端各种文本文件预览 文本编辑excel预览编辑 pdf预览word预览 excel下载pdf下载word下载

前端各种文本文件预览 文本编辑excel预览编辑 pdf预览word预览 excel下载pdf下载word下载 各种文本文件预览(pdf, xlsx, docx, cpp, java, sql, py, vue, html, js, json, css, xml, rust, md, txt, log, fa, fasta, tsv, csv 等各种文本文件) 其中 除p…

MyBatis 配置与测试方式

目录 一,什么是MyBatis 二,准备工作 创建项目 配置数据库连接 持久层代码 单元测试 一,什么是MyBatis 简单来说,MyBatis 是一款优秀的持久层框架,用于简化JDBC的开发,能更简单完成程序与数据库之间…

“AI+Security”系列第2期(一):对抗!大模型自身安全的攻防博弈

近日,由安全极客、Wisemodel 社区和 InForSec 网络安全研究国际学术论坛联合主办的“AISecurity”系列第 2 期——对抗!大模型自身安全的攻防博弈线上活动如期举行。本次活动邀请了君同未来创始人兼 CEO 韩蒙、前阿里云高级安全专家郑瀚、ChaMd5 AI 组负…

git 提交到远程仓库了怎么撤回

有多种方式撤回,以下这种方式算是最安全的一种方式,原理是通过创建一个新的提交来“反做”之前的提交。这不会改变项目的历史记录 1. **查找提交**: - 使用 git log -n 10 查看历史提交的hash值 2. **找到要撤回的提交**: - 在输出中找到你想要撤…

江科大/江协科技 STM32学习笔记P21

文章目录 ADC模数转换器ADC简介逐次逼近型ADCSTM32的ADCADC基本结构输入通道转换模式单次转换,非扫描模式连续转换,非扫描模式单次转换,扫描模式连续转换,扫描模式 触发控制数据对齐转换时间校准硬件电路电位器产生可调电压的电路…

【TabBar嵌套Navigation案例-按钮交换图片和文字的位置-分类 Objective-C语言】

一、接下来,我们接着来说这个Button的问题, 1.首先,我要做的事情,就是让它们两个去交换位置, 那么这个时候,我要去自定义一个东西, 然后,我现在要来到发现这个页面的View里边,我要去自定义一个Button, New一个File, 来一个Cocoa Touch Class, 然后,继承的是UIB…

成功解决7版本的数据库导入 8版本数据库脚本报错问题

我 | 在这里 ⭐ 全栈开发攻城狮、全网10W粉丝、2022博客之星后端领域Top1、专家博主。 🎓擅长 指导毕设 | 论文指导 | 系统开发 | 毕业答辩 | 系统讲解等。已指导60位同学顺利毕业 ✈️个人公众号:热爱技术的小郑。回复 Java全套视频教程 或 前端全套视频…

IPC进程间通信

信号 信号是一种终端机制,程序运行到一半的时候接收到了某种通知,程序就会立刻中断运行,转而去处理通知。 登记信号 一个进程只会接收默认的几个信号 如果想要让一个进程接收特定信号的话,必须提前在该进程中登记一下想要接收…