gpt4 book ai didi

java - Log4j 属性被忽略

转载 作者:太空宇宙 更新时间:2023-11-04 10:00:55 25 4
gpt4 key购买 nike

我在 Eclipse 中有标准的 Maven 项目。我的 log4j.properties 文件位于资源文件夹中,如下图所示。我还有一个 commons-logging.properties 文件,用于将可能使用该文件的任何依赖项定向到 log4j 配置文件。

log4j.properties file in project

这是 gradle.build 文件中的依赖项:

plugins {
id 'com.github.johnrengelman.shadow' version '2.0.4'
id 'java'
}

repositories {
mavenCentral()
}

dependencies {
compile group: 'net.sourceforge.tess4j', name: 'tess4j', version: '4.2.1'
compile group: 'org.apache.pdfbox', name: 'pdfbox', version: '2.0.11'
compile group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.9.6'
compile group: 'org.apache.logging.log4j', name: 'log4j-api', version: '2.11.1'
compile group: 'org.apache.logging.log4j', name: 'log4j-core', version: '2.11.1'
testImplementation 'junit:junit:4.12'
}

这是 log4j.properties 文件内容:

# Root logger option
log4j.rootLogger=ERROR, 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

由于 log4j.properties 文件似乎没有被自动拾取,我尝试在主方法中强制加载它:

private static final Logger logger = Logger.getLogger(MainScreenApplication.class);

public static void main(String[] args) throws IOException {
Properties props = new Properties();
props.load(MainScreenApplication.class.getClassLoader().getResourceAsStream("log4j.properties"));
System.out.println(props);
PropertyConfigurator.configure(props);
logger.debug("Starting");
// Ensure configuration is loaded and stuff copied to user PC
ConfigurationManager.getInstance().getConfiguration();
launch(args);
}

启动应用程序会产生以下输出:

{log4j.rootLogger=ERROR, stdout, 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, log4j.appender.stdout=org.apache.log4j.ConsoleAppender}
16:10:10.680 [main] DEBUG com.damco.documenthandler.ui.MainScreenApplication - Starting

显然,log4j.properties 已加载到属性对象中,即,甚至不遵守日期和时间格式,即使配置设置为错误,它也会打印调试消息。

  • 到底为什么记录器不遵循 log4j 配置?

我已经为此奋斗了太久了:)我想让这个工作的原因之一是我正在使用 PDFBox 并希望它也遵循 log4j 配置,因为它在其终结器方法中产生相当多的调试输出。

提前致谢!

最佳答案

静态也可能是rootlogger未知的问题。尝试使用

logger=Logger.getLogger(MainScreenApplication.class); 

完成后

 PropertyConfigurator.configure(props)

关于java - Log4j 属性被忽略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53495475/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com