Maven Pom 文件中的隐式依赖导致Jar冲突问题
作者:大饼卷馒头蘸米饭
在maven项目中遇到这样一个场景
- 项目中的pom文件中,依赖了Spring-core,而Spring-core又隐式的依赖了commons-logging。
- 项目中同时配置了对定时任务quartz 包的依赖,而quartz又隐式依赖了slf4j。
这样项目中既有了commons-logging又有了slf4j。导致在log4j.properties里配置的mybatis的sql显示配置,一直没起作用,直到我查看maven dependencie中的jar包时,才发现项目既依赖了common-logging又引入了slf4j。后来通过排除quartz中的slf4j的依赖
解决了上述冲突的问题
<dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> </exclusion> </exclusions> </dependency>
以后该如何解决这种类似的问题呢。eclipse提供了对隐式依赖jar包的查看功能:在eclipse中打开一个pom文件,在Dependency Hierarchy的Tab页中,就可以查看当前pom文件中显示声明的jar包,及这些显示声明的jar中隐式引入的依赖jar包。
这样就可以查看有哪些隐式的依赖jar会导致jar包冲突了。
Maven 查看jar包依赖关系
使用eclipse操作,在项目中打开pom.xml文件进入Dependency Hierarchy 来查看依赖树
Dependency hierarchy
:依赖层次视图
Resolved dependencies
:依赖关系解析
点击右边jar或者搜索需要查找的jar可以在左边找到对应关系
比如在NewEnergyCheckDemo项目中启动springBoot工程控制台不打印错误信息,那一定是某个日志jar包有冲突导致的,我们就可以直接搜索要查找的jar,我们可以看到在pom.xml文件中依赖了
而Commons-vfs2这个jar包中又隐式依赖了commons-logging
在项目中我们又配置了spring-boot-starter-web的依赖
我们可以看到该jar包又隐式依赖了一些其他的jar包,如spring-boot-starter又包含了spring-boot-starter-logging,该依赖的内容就是springBoot默认的日志框架logback,所以我们在使用springBoot的日志框架时应该先排除commons-vfs2中commons-logging该jar包的依赖.
排除jar包依赖,找到需要排除的jar包点击右键如下图
排除依赖之后的pom.xml坐标如下
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。