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

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

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

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


当前回答

您可以设置log4j的位置。在Java应用程序中使用:

org.apache.log4j.PropertyConfigurator.configure(file/location/log4j.properties)

更多信息请访问:https://logging.apache.org/log4j/1.2/manual.html

其他回答

虽然正确地设置log4j对于“真正的”项目很好,但你可能想要一个快速而肮脏的解决方案,例如,如果你只是在测试一个新库。

如果是,则调用静态方法

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

将在控制台设置基本日志记录,错误消息将消失。

如果我们在log4j之上使用apache公共日志包装器,那么我们需要在类路径中有两个可用的jar。同时,通用日志。属性和log4j。Properties /xml应该在类路径中可用。

我们还可以传递实现类和log4j。使用- doorg .apache.commons.logging. log =<日志实现类名> -Dlog4j. log =<日志实现类名>。配置=<文件:log4j的位置。/ xml文件>属性。在应用/web服务器的情况下,通过设置JAVA_OPTS也可以做到这一点。

它将有助于外部化可以在部署中更改的属性。

简单地说,创建log4j。src/main/assembly文件夹下的属性。根据您希望日志消息显示在控制台中还是显示在您修改的文件中。下面的代码将在控制台中显示您的消息。

# Root logger option
log4j.rootLogger=INFO, stdout

# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

Maven的解决方案:

我遇到了所有与上面相同的问题,对于maven解决方案,我使用了2个依赖项。如果您希望一个简单的项目使用一个标准配置的日志记录器,那么此配置仅用于快速测试。我可以想象,如果您需要更多信息或调整自己的日志级别,您稍后会想要制作一个配置文件。

    <properties>
        <slf4jVersion>1.7.28</slf4jVersion>
    </properties>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>${slf4jVersion}</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-jdk14</artifactId>
            <version>${slf4jVersion}</version>
        </dependency>

我就这么做了,问题就解决了。

关注下面的博客

https://intellij-support.jetbrains.com/hc/en-us/community/posts/206875685-How-to-fix-log4j-WARN-console-messages-when-running-an-Application-inside-IntelliJ-Idea

但是这里他说像下面这样

要修复这个问题,只需输入下面的log4j。资源文件到项目的main/ Resources文件夹

而不是创建log4j。资源,创建log4j.properties。右键单击IntelliJ中的资源-> New -> Resource Bundle -将其命名为log4j