问题描述
- 前端页面停留在导入页面,通过后端返回的接口,确认后端已经抛出异常
- 查看系统调用错误日志为
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>
-
结果启动应用又是另一个异常(待补充截图)
-
那既然升级版本不能解决问题,那就重写源码吧,如下图
-
也可以在GitHub上,给作者提bug,但不能确认什么时候修复问题
-
参照文章: JAVA POI报错