easypoi导入excel空指针异常

问题描述

  • 前端页面停留在导入页面,通过后端返回的接口,确认后端已经抛出异常
  • 查看系统调用错误日志为
java.lang.NullPointerException: null
	at org.apache.poi.xssf.usermodel.XSSFClientAnchor.setCol2(XSSFClientAnchor.java:231)
	at org.apache.poi.ss.util.ImageUtils.setPreferredSize(ImageUtils.java:188)
	at org.apache.poi.xssf.usermodel.XSSFPicture.getPreferredSize(XSSFPicture.java:224)
	at org.apache.poi.xssf.usermodel.XSSFPicture.getPreferredSize(XSSFPicture.java:213)
	at org.apache.poi.xssf.usermodel.XSSFPicture.getPreferredSize(XSSFPicture.java:203)
	at cn.afterturn.easypoi.util.PoiPublicUtil.getSheetPictrues07(PoiPublicUtil.java:207)
	at cn.afterturn.easypoi.excel.imports.ExcelImportService.importExcelByIs(ExcelImportService.java:453)
	at cn.afterturn.easypoi.excel.ExcelImportUtil.importExcelMore(ExcelImportUtil.java:99)
	at com.tcl.***TmsExcelImportManager.parseData(TmsExcelImportManager.java:58)
  • 通过用户提供的能导入的Excel和不能导入的Excel对比,最后定位是这个柜号有问题
    在这里插入图片描述
  • 对比7788柜号与正常能导入的Excel单元格、样式等对比,没有发现问题。如果将7788柜号文本直接复制,是可以导入

问题定位

  • 在easypoi中找到异常调用位置
    在这里插入图片描述

  • 看方法备注,是读取图片,但是在不能导入Excel中没有找到图片,所以百思不得其解

  • 那么会不会是版本不一致导致的冲突呢
    pom.xml - Dependency Analyzer
    apache poi 依赖版本

  • 当前项目强制依赖高版本

<dependency>
	<groupId>cn.afterturn</groupId>
	<artifactId>easypoi-base</artifactId>
	<version>4.4.0</version>
</dependency>
<dependency>
	<groupId>cn.afterturn</groupId>
	<artifactId>easypoi-web</artifactId>
	<version>4.4.0</version>
</dependency>
<dependency>
	<groupId>cn.afterturn</groupId>
	<artifactId>easypoi-annotation</artifactId>
	<version>4.4.0</version>
</dependency>
  • 结果发现apache 的 poi版本过低,再次升级版本
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi</artifactId>
	<version>5.0.0</version>
</dependency>
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi-ooxml</artifactId>
	<version>5.0.0</version>
</dependency>
<!-- maven中央仓库等没有如下依赖 -->
<!--		<dependency>-->
<!--			<groupId>org.apache.poi</groupId>-->
<!--			<artifactId>poi-ooxml-schemas</artifactId>-->
<!--			<version>5.0.0</version>-->
<!--		</dependency>-->

在这里插入图片描述

  • 通过这个博客知道,poi-ooxml-schemas是简易版本,增加的依赖如下
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi-scratchpad</artifactId>
	<version>5.0.0</version>
</dependency>
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi-ooxml-full</artifactId>
	<version>5.0.0</version>
</dependency>

<dependency>
	<groupId>org.apache.xmlbeans</groupId>
	<artifactId>xmlbeans</artifactId>
	<version>4.0.0</version>
</dependency>
  • 结果启动应用又是另一个异常
poi-ooxml-schemas 使用 4.12 版本导致的
  • 既然升级版本不能解决问题,那就重写源码(将涉及到的源码拷贝到当前项目),如下图
    在这里插入图片描述

  • 也可以在GitHub上,给作者提bug,但不能确认什么时候修复问题

  • 参照文章: JAVA POI报错

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值