问题现状
由于是一个迭代比较久的项目,项目中已经存在poi-tl 1.5.x的依赖,poi-tl v1.5.x是构建在Apache poi3.16上的版本,而我们现在要使用到easyexcel来处理导出,而easyexcel最低的Apache poi版本要求是4.1.2,将项目中已有poi的3.16升级到4.12时,旧代码出错,但是不升级就无法使用easyexcel。
解决思路
解决问题思路无非就是两种:
- 将项目中已有的poi3.16升级到4.12,解决升级后代码出错的地方;优点:jar包依赖清晰,在代码改动量可控的情况下,推荐使用该方式;缺点:代码改动量大,工作量大,而且容易对之前的功能带来不稳定因素;
- 使用maven-shade-plugin插件来解决,让项目依赖多个版本的poi版本;优点:对原来的功能无影响,代码改动量小;缺点:jar依赖变大,因为依赖了同一个依赖的2个版本;jar包依赖不那么清晰优雅;
今天文章主角就是第2种方式。
它的核心思路就是把easyexcel中的高版本poi包改个名字,同时easyexcel中引用的地方也改名(自动),并且代码中用高本版的地方也改个名(手动)。
解决问题
- 创建一个空maven项目,项目名称为jarjar,引入easyexcel的依赖;<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>3.1.1</version>
</dependency>
查看其依赖的poi版本
- 引入插件并且配置好修改的方式;<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</art