问题发生的背景
我们项目需要对接不同银行提供的接口,每个银行依赖不同版本的bcprov-jdk15on
包,而bcprov-jdk15on
包,前后版本兼容做的不是很好,那么意味着我们确实需要在项目中需要存在多个不同版本的jar包。
方案选择
基于我们JDK还是1.8,非容器部署,可以选择以下两个方案去解决这件事
1. 分module
A银行需要引用1.55版本的jar包,将A银行的接口单独写在一个module里;同理B银行使用1.68版本的jar包,给B银行的接口也封装到一个module里。最后建立一个biz的module,将不同的module引入进来,在这里实现集成业务代码。
2. 使用jarjar工具,重新打包jar包
使用google提供的jarjar.jar这个工具,将bcprov-jdk15on
包重新打包,我们打包的目的是把重打包的文件换一个包路径,不同的包路径引用的类就不会冲突了。例如bcprov-jdk15on-1.55.jar
保持不动,项目就引用这个版本的包,而针对bcprov-jdk15on-1.68.jar
,我们进行重新打包。打包的步骤也很简单:
- 下载jarjar.jar工具,这里我下载的是jarjar-1.4.jar
可以去官网下载
https://code.google.com/archive/p/jarjar/downloads
- 新建rule.txt文件,编写rule规则(用于包名替换)
rule org.bouncycastle.** org.shade168.bouncycastle.@1
- 执行命令
java -jar jarjar-1.4.jar process rule.txt bcprov-jdk15on-1.68.jar shade168-bcprov-jdk15on-1.68.jar
按照上面的步骤执行完后,我们可以得到一个新的jar包shade168-bcprov-jdk15on-1.68.jar
,这个包除了里面文件的包路径被替换,其余与原先一模一样,将新的包放入工程,pom文件引入这个新包即可实现目的。
可能遇到的问题
jar包经过jarjar重新打包后包路径没有被替换
在实际操作中, 我对hutool-crypto
包进行重打包时,发现重打包后并没有改变其包路径,使用
java -jar jarjar-1.4.jar strings hutool-crypto-5.8.25.jar
试图查看包内包名,发现报错Error reading,如下图
搜索了下相关内容,原贴如下
https://stackoverflow.com/questions/43304586/jarjar-not-renaming-references
。
问题的原因是 jarjar这个工具,使用的asm4.0框架,不支持JDK8的字节码,而贴心的网友也提供了一个使用asm5.0框架开发的jarjar工程。下载编译后,可以本地直接运行这个代码,生成重命名jar包。
我稍微修改了下代码,方便你们即开即用,下载这个代码后,自己重新配置下maven配置,找到Main类,找到其中的main()
方法, 自己替换下相关的规则文件路径、原始jar包路径、替换完后新生成的jar包路径,执行main()
方法即可得到新jar包。
文件下载
1. jarjar1.4版本
链接: https://pan.baidu.com/s/11Zad4ie_bOWsUGOh7zvjTg?pwd=m66b 提取码: m66b 复制这段内容后打开百度网盘手机App,操作更方便哦
2. 使用asm5.0框架写的jarjar项目
链接: https://pan.baidu.com/s/1YC76-xiPy_UrJIz-Py_JnQ?pwd=neum 提取码: neum 复制这段内容后打开百度网盘手机App,操作更方便哦