easypoi导入excel空指针异常

news/2024/7/21 4:08:48 标签: 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>
  • 结果启动应用又是另一个异常(待补充截图)

  • 那既然升级版本不能解决问题,那就重写源码吧,如下图
    在这里插入图片描述

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

  • 参照文章: JAVA POI报错


http://www.niftyadmin.cn/n/18141.html

相关文章

【Linux修炼手册:基本指令(完结)】

Life is about waiting for the right moment to act. 目录 1 zip/unzip指令 2 tar指令&#xff08;重要&#xff09;&#xff1a;打包/解包&#xff0c;不打开它&#xff0c;直接看内容 3 bc指令 4 uname –r指令 5 重要的几个热键[Tab],[ctrl]-c, [ctrl]-d 6 shutdown 7…

springboot之多数据源---1

一、多数据源的典型使用场景 在实际开发中&#xff0c;经常可能遇到在一个应用中可能需要访问多个数据库的情况。以下是两种典型场景&#xff1a; 1 业务复杂&#xff08;数据量大&#xff09; 数据分布在不同的数据库中&#xff0c;数据库拆了&#xff0c; 应用没拆。 一个公司…

Vue实现后台管理系统

目录 前言 登录页面 后台界面 前言 今天用Vue实现一个简易的后台&#xff0c;不借助接口和后端代码&#xff0c;仅通过前端实现&#xff0c;本案例涉及Vue路由相关知识&#xff0c;不熟悉Vue路由可以先看一下右边的文章再接着看下面的项目案例&#xff1a;Vue路由 这篇文章详…

汽车ECU通信相关验证项有哪些?

已剪辑自: https://mp.weixin.qq.com/s/-fIAXkS37r6jvnuA7yIQDA 汽车电子的高速发展决定了基础软件所面临的要求将会更加严格&#xff0c;其要求会覆盖软件的安全性、稳定性、可扩展性等方方面面。为了提高软件质量&#xff0c;降低软件应用风险&#xff0c;构建高安全、高可靠…

Python基础 - 本地模块的相对导入/引用

如果把绝对和相对导入都放在一个文章写&#xff0c;会显得过于冗长&#xff0c;所以我分开来写&#xff0c;我将会延续上一篇文章Python基础 - 本地模块的绝对导入的文件树和示例来讲相对引用&#xff0c;以及常见的一些问题。没看上一篇的小伙伴可以先去把上一篇看完&#xff…

Vue2+Vue3的专题目录结构(第二十三课)

这个世界有些事情真的是无法改变的&#xff0c;我们唯一能做的&#xff0c;只是在自己与世界之间找到一个平衡点。 了解Vue框架的大致学习方向(第一课)_星辰镜的博客-CSDN博客Vue框架的学习(Vue的基础指令操作一)第二课_星辰镜的博客-CSDN博客_error: git config user.name &am…

数据挖掘Java——DBSCAN算法的实现

一、DBSCAN算法的前置知识 DBSCAN算法&#xff1a;如果一个点q的区域内包含多于MinPts个对象&#xff0c;则创建一个q作为核心对象的簇。然后&#xff0c;反复地寻找从这些核心对象直接密度可达的对象&#xff0c;把一些密度可达簇进行合并。当没有新的点可以被添加到任何簇时…

IfcOpenShell正确设置几何体的坐标

在之前的文章中&#xff0c;我们使用 IfcOpenShell (IOS) 读取 ifc 几何并将其转换为 brep。 当我们读取 wikilab.ifc文件时&#xff0c;一切似乎都是正确的&#xff0c;但真的如此吗&#xff1f; 当你在项目中使用 BIM 时&#xff0c;坐标始终是正确讨论的主题。 就此而言&am…