背景

很多是时候,在使用maven依赖jar包时,会由于某个jar包被重复依赖,且版本不一致,导致项目无法启动,或启动后,使用某个jar包报错如:最常见 log4j-api 依赖包版本不一致,导致启动项目时报红

解决示例:

示例

比如:当前项目中存在重复依赖mybatis:3.5.9 和 mybatis:3.5.10,如下(图1)所示现在我们想保留mybatis:3.5.10,排除掉mybatis:3.5.9下图就是idea显示的当前项目依赖关系图,从图中我们可以看出,mybatis存在重复依赖,且版本不一致 第一步:显示module中所有依赖关系图(多module时,哪个module存在重复依赖,就显示哪个)

在idea右侧【toolbar】中,打开【maven】工具窗口选中【需要处理的model】,然后点击【show dependencies】如下(图2)所示 第二步:搜索存在冲突的依赖包名

在【依赖关系图】窗口中,按【Ctrl + F】进行打开【Diagram Elements】窗口,然后直接搜索存在冲突的依赖包名称比如:当前我的项目中,mybatis存在重复依赖包,所以搜【mybatis】注意:虽然 Diagram Elements 窗口没有搜索框,但是当键入字符时,会自动进入搜索模式如下(图3)所示 第三步:抽取选中依赖包的整个依赖关系图

搜索到需要的依赖后,鼠标直接点击依赖包,再点击【Root -> Selection】按钮,idea会自动将依赖从Root(根)到当前所选的依赖包的关系图给抽离出来,并展示比如:这里我们想找到【mybatis:3.5.10】这个依赖,如下(图4)所示 当我们点击【Root->Selection】后,idea将选中依赖关系图抽取如下(图5)所示 如果觉得不方便看,可以选择【Export Diagram】按钮,将关系图导出,操作如下(图6)所示 操作导出后,idea会自动在浏览器中打开到处结果,并如下(图7)所示 第四步:分析依赖关系

从上面(图5)或(图7)中,我们没有看到【mybatis:3.5.10】与哪个包存在重复依赖,所以,我们需要再去检查一下【mybatis:3.5.9】依赖包是否有问题。同理,我们将【mybatis:3.5.9】依赖包关系图抽取出来,如下(图8和图9)所示 第五步:找到重复依赖是从哪里被引入进来的(以便后续分析和解决问题)

从上面 图8 和 图9 中,我们并不知道【mybatis:3.5.9】是从哪个依赖包中被引入进来的。想要找到【mybatis:3.5.9】是从哪个依赖包中引入进来的,只需要双击【mybatis:3.5.9】依赖包(下图10),idea就会自动打开其父依赖的所在pom文件 我们从idea自动打开的pom文件中(下图11),可以确认【mybatis:3.5.9】是在【mybatis-spring-boot-starter-2.2.2.pom】中引入的 抽取【mybatis:3.5.9】的父依赖【mybatis-spring-boot-starter:2.2.2】的依赖关系图,结果如下(图12 和 图13)所示 第六步:确定取舍依赖包

上面找到了【mybatis:3.5.9】和 【mybatis:3.5.10】两个依赖的关系图(为了方便,我将两个依赖图放在下面一起看)。接下来就是要分析这两个依赖,应该要排除掉哪个依赖,保留哪个依赖【mybatis:3.5.10】是项目中的【mybatis-plus-boot-starter:3.5.2】引入的,该jar包是用来进行数据库操作的【mybatis:3.5.9】是项目中【pagehelper-spring-boot-starter:1.4.6】引入的,该jar包是用来进行分页的插件故:从影响面考虑,应该排除【pagehelper-spring-boot-starter:1.4.6】引入的【mybatis:3.5.9】Tips:这里,我们可以发现,其实在搜【mybatis:3.5.9】时,就已经给出其依赖关系图,只是少了一个连接线而已(如下左边图中红线) 第七步:排除重复依赖

根据上面分析的结果,本次示例中,我们需要排除【mybatis:3.5.9】依赖包【mybatis:3.5.9】是被【pagehelper-spring-boot-starter:1.4.6】引入进来的故:在引入【pagehelper-spring-boot-starter:1.4.6】的地方,进行排除操作即可,如下(图15)所示 最后:验证排除结果

再次打开【show dependencies】,并搜索【mybatis】发现此时只有一个【mybatis:3.5.10】依赖包如下(图16)所示

好文阅读

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: