解决POi冲突总结(当项目存在多个POI依赖时)

一、问题背景:

        项目同时引入了easy excel和自动化测试框架concordion-excel-extension,这两个依赖都制定了内置了POI版本,我的冲突是POI3.14和4.1.2,导致了在easy excel使用时依赖混论,找不到方法。报错:

Caused by: java.lang. NoClassDefFoundError: org/apache/poi/util/IOUtils

Caused by: java. lang. NoSuchMethodError: org.apache.poi.util.Ioutils.peekrirstNBytes (Ljava/io/Input Stream;I

com.alibaba.excel.exception.ExcelAnalysisException:java.lang.NoSuchMethodError:org.apache.poi.util.IOUtils.peekFirstNBytes

其实就是两个POI提供的方法不一样,当依赖混乱时就会找不到对应版本的对应方法

二、解决方案

1)、找到中间版本(治标不治本)

这种方案的前提是必须保留两个POI版本,因为各自依赖不同。如果可以去掉一个提升版本依赖是最好的,如果不能的情况下那只能找到中间版本,但这样又会增加一个版本依赖。例如我的冲突时3.14和4.12那么中间版本就是POI3.16

            	
<dependency>
      <groupId>org.apache.poi</groupId>
      <artifactId>poi</artifactId>
     <version>3.16</version>
  </dependency>
       
  <dependency>
   <groupId>org.apache.poi</groupId>
     <artifactId>poi-ooxml</artifactId>
  <version>3.16</version>
</dependency>
<dependency>
   <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml-schemas</artifactId>
   <version>3.16</version>
</dependency>
2)、治标治本

可以将easy excel源代码克隆,官网提供了各个版本的代码,克隆下来之后。将easy excel所依赖的POI版本重新打包,也就是起别名。这样的话隔离性好,同时可以管理自由maven。具体实现方式如下:

  • 准备打包资源

poi及jarjar

  • 创建rule.txt

  • rule.txt中写入文本
rule org.apache.poi.**  com.customize.poi.@1
  • 重新打包
java -jar jarjar-1.3.jar process rule.txt poi-3.17.jar customize-poi-3.17.jar
java -jar jarjar-1.3.jar process rule.txt poi-ooxml-3.17.jar customize-poi-ooxml-3.17.jar
java -jar jarjar-1.3.jar process rule.txt poi-ooxml-schemas-3.17.jar customize-poi-schemas-3.17.jar

新的jar包

  •  打包到本地仓库
mvn install:install-file -Dfile=customize-poi-3.17.jar -DgroupId=com.customize -DartifactId=poi -Dversion=3.17 -Dpackaging=jar

mvn install:install-file -Dfile=customize-poi-ooxml-3.17.jar -DgroupId=com.customize -DartifactId=poi-ooxml -Dversion=3.17 -Dpackaging=jar

mvn install:install-file -Dfile=customize-poi-schemas-3.17.jar -DgroupId=com.customize -DartifactId=poi-ooxml-schemas -Dversion=3.17 -Dpackaging=jar

  • 下载easy excel源码

  •  修改依赖
<dependency>
   <groupId>com.customize</groupId>
   <artifactId>poi</artifactId>
   <version>3.17</version>
</dependency>

<dependency>
   <groupId>com.customize</groupId>
   <artifactId>poi-ooxml</artifactId>
   <version>3.17</version>
</dependency>

<dependency>
   <groupId>com.customize</groupId>
   <artifactId>poi-ooxml-schemas</artifactId>
   <version>3.17</version>
</dependency>
  • 修改项目坐标
<groupId>com.customize</groupId>
 <artifactId>easyexcel</artifactId>
 <version>2.2.6</version>
 <packaging>jar</packaging>
 <name>easyexcel</name>
  • 全局替换

在这里插入图片描述

  •  编译
mvn clean install -DkispTests=true
  • 使用
<dependency>
      <groupId>com.customize</groupId>
      <artifactId>easyexcel</artifactId>
      <version>2.2.6</version>
  </dependency>
<dependency>
     <groupId>com.customize</groupId>
     <artifactId>poi</artifactId>
     <version>3.17</version>
 </dependency>

 <dependency>
     <groupId>com.customize</groupId>
     <artifactId>poi-ooxml</artifactId>
     <version>3.17</version>
 </dependency>

 <dependency>
     <groupId>com.customize</groupId>
     <artifactId>poi-ooxml-schemas</artifactId>
     <version>3.17</version>
 </dependency>

三、引用

方案一是一个大佬想到的,这里无法提名

方案二参考文章:

叹一曲当时只道是寻常

比我写的要详尽很多,有不懂的可以看看这个

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
POI是Apache软件基金会推出的一款用于操作Microsoft Office格式文件的Java库。它可以帮助我们读取、创建和修改Excel文件。 在POI中,Sheet页可以理解为Excel文件中的工作表,而一个Sheet页可以包含多个表头。表头通常用于标识和描述该Sheet页中数据的每一列。 在创建一个带有多个表头的Sheet页,首先需要创建一个Sheet对象,然后通过调用该对象的createRow方法创建行对象,最后在行对象中使用createCell方法创建单元格对象并设置单元格的值。 将多个表头写入到Sheet页中的步骤如下: 1. 创建Sheet对象:使用Workbook对象的createSheet方法创建一个Sheet对象,可指定Sheet页的名称和索引。 2. 创建行对象:使用Sheet对象的createRow方法创建一个行对象,表示Sheet页中的一行数据。 3. 创建单元格对象:使用行对象的createCell方法创建多个单元格对象。 4. 设置表头值:使用单元格对象的setCellValue方法将表头的值设置到对应的单元格中。 5. 设置表头样式:使用POI提供的样式类和字体类,可以设置表头的样式,包括字体、颜色、边框等。 6. 重复步骤2-5,直到将所有表头的值设置完成。 7. 将Sheet页写入到Excel文件中:使用Workbook对象的write方法将Sheet页写入到Excel文件中。 总的来说,POI可以很方便地操作Excel文件,在创建Sheet页,我们可以根据需求来设置多个表头,通过调用POI提供的方法将表头值写入到对应的单元格中。这样就可以实现一个Sheet页中包含多个表头的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值