问题描述:
使用Springboot+Hutool+POI读取Excel报错
版本:
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.3</version>
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.10</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.1.2</version>
</dependency>
报错相关代码:
InputStream inputStream;
int count = 0;
List<List<Object>> list;
try {
inputStream = file.getInputStream();
//报错定位在本行
ExcelReader excelReader = ExcelUtil.getReader(inputStream);
...
报错信息:
Your InputStream was neither an OLE2 stream, nor an OOXM
解决过程:
经查询资料,报错可能情况有:
1.文档不是真实的Excel文件,是xml文件【不符合,我用wps和office新建的Excel文件xls和xlsx都报错】
2.文档加密【不符合】
经查看源码,POI会判断文档类型,如果不是OLE2或OOXM类型就会抛出异常
解决方案
升级poi-ooxml至最新版本5.2.3,最新版本对文档类型的判断有更新,可以正确识别文件类型
<!-- <dependency>-->
<!-- <groupId>org.apache.poi</groupId>-->
<!-- <artifactId>poi-ooxml</artifactId>-->
<!-- <version>4.1.2</version>-->
<!-- </dependency>-->
<!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>5.2.3</version>
</dependency>