在添加log4j到我的应用程序后,每次执行我的应用程序时,我都会得到以下输出:

log4j:WARN No appenders could be found for logger (slideselector.facedata.FaceDataParser).
log4j:WARN Please initialize the log4j system properly.

这似乎意味着一个配置文件丢失了。 这个配置文件应该放在哪里,一个好的开始内容是什么?

我正在使用纯java开发桌面应用程序。所以没有网络服务器等等…


当前回答

要启用-Dlog4j.debug,我进入系统,高级系统设置,环境变量,并设置系统变量_JAVA_OPTIONS为-Dlog4j.debug。

其他回答

尝试将log4j:configuration节点中的调试属性设置为true。

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="true">

它在读取配置文件时输出信息,并用于配置log4j环境。你可能会得到更多细节来解决你的问题。

默认情况下,Log4j查找一个名为Log4j的文件。属性或类路径上的log4j.xml。

您可以通过设置这里描述的系统属性来控制它使用哪个文件来初始化自己(请参阅“默认初始化过程”部分)。

例如:

java -Dlog4j.configuration=customName ....

将导致log4j在类路径上查找名为customName的文件。

如果你有问题,我发现打开log4j.debug很有帮助:

-Dlog4j.debug

它将打印到系统。给出了很多有用的信息,比如它使用哪个文件来初始化自己,哪个记录器/追加器被配置了,以及如何配置等等。

配置文件可以是java属性文件,也可以是xml文件。下面是来自log4j介绍文档页面的属性文件格式示例:

log4j.rootLogger=debug, stdout, R

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout

# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n

log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.log

log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=1

log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n

你在发展什么?您是否使用Apache Tomcat?

log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.target=System.out
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{yyyyMMdd HH:mm:ss.SSS} [[%5p] %c{1} [%t]] %m%n

我在我的Java应用程序中有一个这样的属性。

如果您在Intellij IDEA上出现此错误,即使添加了log4j。如果您的资源测试文件夹中存在log4j. properties或log4j.xml文件,可能Intellij IDEA还不知道该文件的存在。

因此,在添加文件之后,右键单击该文件并选择Recompile log4j.xml。

如果你把所有东西都扔掉(比如你在考试)

org.apache.log4j.BasicConfigurator.configure(new NullAppender());