我可以在运行时更改Log4Qt配置的文件名吗?

时间:2012-12-13 21:31:33

标签: c++ qt logging log4cplus

我正在使用Log4qt,我按照official steps配置了日志文件。我想知道是否可以在运行时动态更改配置。假设默认文件是“myapp.log”

// Set logging level for Log4Qt to TRACE
s.beginGroup("Log4Qt");
s.setValue("Debug", "TRACE");

// Configure logging to log to the file C:/myapp.log using the level TRACE
s.beginGroup("Properties");
s.setValue("log4j.appender.A1", "org.apache.log4j.FileAppender");
s.setValue("log4j.appender.A1.file", "C:/myapp.log");
s.setValue("log4j.appender.A1.layout", "org.apache.log4j.TTCCLayout");
s.setValue("log4j.appender.A1.layout.DateFormat", "ISO8601");
s.setValue("log4j.rootLogger", "TRACE, A1");

// Log first message, which initialises Log4Qt
Log4Qt::Logger::logger("MyApplication")->info("Hello World");

我想在运行时更改文件名,就像这样?

QSettings s;
s.beginGroup("Properties");
s.setValue("log4j.appender.A1.file", "C:/NewFile.log");

// Log first message, into new file
Log4Qt::Logger::logger("MyApplication")->info("Hello World");

1 个答案:

答案 0 :(得分:2)

看起来在更改QSettings之后,它们会反映在那里,您需要使用:

Log4Qt::Properties::load()

Log4Qt::PropertyConfigurator::configure()

引用您的QSettings变量。如果这不适用于文件名更改,您可能需要寻找一种在Log4Qt单例上运行启动的方法。

希望有所帮助。