原因:
项目中用的是commons-logging的日志框架,而jar中用的是slf4j的日志框架,slf4j和commons-logging是两个不同的日志框架,这样项目打印日志会冲突,只能打印commons-logging的日志,不能打印slf4j的日志(如果引用的jar包没有日志框架,单个项目是可以两个日志框架共存的)
解决:
①
添加依赖,slf4j打印日志将引用commons-logging的驱动
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-jcl</artifactId>
<version>1.7.7</version>
</dependency>
②
添加依赖,使用log4j和slf4j的桥接,将slf4j转为log4j打印,因为项目中commons-logging也是转为log4j打印的,所以这个依赖更符合项目的要求
注意:版本需要和log4j的版本一致,不然项目会抛异常
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<version>2.1</version>
</dependency>
备注:
依赖导入需要放在pom.xml中所有依赖的顶部,不然会冲突(例如①与slf4j-log4j12.jar冲突),类加载顺序的问题