今天用maven構(gòu)建一個spring4+mybatis的項目遇到了一個小問題
配置log4j2.xml文件不起作用撵彻。
調(diào)查了一番發(fā)現(xiàn)slf4j的jar用錯了艺演。
修改前引用的包
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>${slf4j.version}</version>
<scope>runtime</scope>
</dependency>
上面用的是jcl-voer-slf4j
用這個的時候log4j2.xml不起作用,只有l(wèi)og4j 1的配置方式起作用
后來改成
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
<version>${slf4j.version}</version>
</dependency>
用的是log4j-over-slf4j
這回log4j2.xml起作用了
具體原因請參照下面的文章贱傀,非常感謝文章的作者惨撇,要不就是不知其所以然了。
spring項目slf4j
順便說一下,用servlet3窍箍,log4j2在web.xml里邊配置可以不寫了
就是下面這個
<context-param>
<param-name>log4jConfiguration</param-name>
<param-value>classpath:log4j2.xml</param-value>
</context-param>