当前位置:   article > 正文

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

easyexcel和poi依赖冲突

一、问题背景:

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

  1. Caused by: java.lang. NoClassDefFoundError: org/apache/poi/util/IOUtils
  2. Caused by: java. lang. NoSuchMethodError: org.apache.poi.util.Ioutils.peekrirstNBytes (Ljava/io/Input Stream;I
  3. com.alibaba.excel.exception.ExcelAnalysisException:java.lang.NoSuchMethodError:org.apache.poi.util.IOUtils.peekFirstNBytes

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

二、解决方案

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

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

  1. <dependency>
  2. <groupId>org.apache.poi</groupId>
  3. <artifactId>poi</artifactId>
  4. <version>3.16</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.apache.poi</groupId>
  8. <artifactId>poi-ooxml</artifactId>
  9. <version>3.16</version>
  10. </dependency>
  11. <dependency>
  12. <groupId>org.apache.poi</groupId>
  13. <artifactId>poi-ooxml-schemas</artifactId>
  14. <version>3.16</version>
  15. </dependency>
2)、治标治本

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

  • 准备打包资源

poi及jarjar

  • 创建rule.txt

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

新的jar包

  •  打包到本地仓库
  1. mvn install:install-file -Dfile=customize-poi-3.17.jar -DgroupId=com.customize -DartifactId=poi -Dversion=3.17 -Dpackaging=jar
  2. mvn install:install-file -Dfile=customize-poi-ooxml-3.17.jar -DgroupId=com.customize -DartifactId=poi-ooxml -Dversion=3.17 -Dpackaging=jar
  3. 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源码

  •  修改依赖
  1. <dependency>
  2. <groupId>com.customize</groupId>
  3. <artifactId>poi</artifactId>
  4. <version>3.17</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>com.customize</groupId>
  8. <artifactId>poi-ooxml</artifactId>
  9. <version>3.17</version>
  10. </dependency>
  11. <dependency>
  12. <groupId>com.customize</groupId>
  13. <artifactId>poi-ooxml-schemas</artifactId>
  14. <version>3.17</version>
  15. </dependency>
  • 修改项目坐标
  1. <groupId>com.customize</groupId>
  2. <artifactId>easyexcel</artifactId>
  3. <version>2.2.6</version>
  4. <packaging>jar</packaging>
  5. <name>easyexcel</name>
  • 全局替换

在这里插入图片描述

  •  编译
mvn clean install -DkispTests=true
  • 使用
  1. <dependency>
  2. <groupId>com.customize</groupId>
  3. <artifactId>easyexcel</artifactId>
  4. <version>2.2.6</version>
  5. </dependency>
  1. <dependency>
  2. <groupId>com.customize</groupId>
  3. <artifactId>poi</artifactId>
  4. <version>3.17</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>com.customize</groupId>
  8. <artifactId>poi-ooxml</artifactId>
  9. <version>3.17</version>
  10. </dependency>
  11. <dependency>
  12. <groupId>com.customize</groupId>
  13. <artifactId>poi-ooxml-schemas</artifactId>
  14. <version>3.17</version>
  15. </dependency>

三、引用

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

方案二参考文章:

叹一曲当时只道是寻常

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/170246
推荐阅读
相关标签
  

闽ICP备14008679号