事件背景:
我的log4j和self4j按照网上的配置,配置成功了,但是报错如下:
让我很是郁闷,于是找了一大圈。。。。。。。。
解决方案:
总结来说就是:log4j.properties和logback.xml这两个放的文件(这两个方案源自于网上)
1、配置文件放到 classpath 目录即:target/classes
2、设置 resources 目录为 Resource roots
根据 Maven 标准目录结构, main 和 test 目录下都会有 resources 目录:
src/main/java Application/Library sources (java源代码文件,会自动编译到classes文件夹下)
src/main/resources Application/Library resources (资源库,会自动编译到classes文件夹下)
src/test/java Test sources (测试java源代码文件)
src/test/resources Test resources (测试需要的资源库)
简单总结
log4j.properties放到src/test/resources下
logback.xml放到src/main/resources下
------------------------------------------------------分割线------------------------------------------------------------------------
以上并没有解决我的问题,因为我的配置放的位置并没有错误
于是,我又再次查询slf4j+logback配置和logback.groovy配置方式相关资料
结果发现是因为引入的依赖jar的问题,pom中引用这几个版本的jar完美解决问题
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.5.6</version>
<type>jar</type>
</dependency> <dependency>
<groupId>slf4j-simple</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.5.2</version>
</dependency> <dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.1.2</version>
</dependency> <dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.14</version>
<scope>provided</scope>
</dependency>
再次运行代码结果如下:
到此结束,成功修复这个问题!