POI读取Excel报错:Your InputStream was neither an OLE2 stream, nor an OOXM

问题描述:

使用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>
  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值