简单java maven项目中的eclipse log4j
我有一个简单的java项目。我用maven管理我的依赖关系。我在pom中添加了log4j依赖项。xml
现在我想利用
package com.abc.xyz;
import org.apache.log4j.Logger;
/**
* Hello world!
*
*/
public class App
{
static final Logger logger = Logger.getLogger(App.class);
public static void main( String[] args )
{
logger.debug("Hello world!");
}
}
我有我的log4j。资源文件夹中的属性文件
当我将应用程序作为Java应用程序运行时,会出现以下错误
log4j:WARN No appenders could be found for logger (com.abc.xyz.App).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
所以,我的问题是如何让运行时知道我的log4j。属性文件位于资源文件夹中
编辑
这是我的pom。xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.abc.xyz</groupId>
<artifactId>learning</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>learning</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
这是我的log4j。属性文件
# Define the root logger with appender file
log4j.rootLogger = DEBUG
# 1 楼答案
将系统属性
log4j.configuration
设置为文件的运行时路径。这可以在应用程序启动器中完成。类似这样,假设您的配置文件位于工作目录的根目录中(因为您说过您的文件位于src/main/resourcesmaven会将其移动到根目录中)但是我必须说,如果你的文件真的叫做log4j。属性,它实际上位于src/main/resources中,您不应该需要它,因为默认情况下log4j将在那里查找它
# 2 楼答案
换你的pom。log4j的xml依赖关系到此:
看看它是否有效
# 3 楼答案
我修改了我的应用程序类,如下所示:
# 4 楼答案
您应该放置log4j。项目的
src/main/resources
文件夹下的属性,以避免警告或使用-Dlog4j.configuration=<FILE_PATH>
提供文件路径