我希望这个问题有一个简单的答案。我正在尝试将记录器添加到我的 Java 应用程序。我能够完美地格式化日志文件,但是在尝试将 ConsoleHandler 添加到记录器以格式化控制台输出时遇到了问题。
添加 ConsoleHandler 后,每条日志消息都不会打印三次,两次以我想要的正确格式打印,然后一次以我不想要的原始格式打印。
我会在下面发布我的代码,完全不确定我做错了什么。
任何帮助将不胜感激。
// remove and handlers that will be replaced
Handler[] handlers = logger.getHandlers();
for(Handler handler : handlers)
{
if(handler.getClass() == ConsoleHandler.class || handler.getClass() == FileHandler.class)
logger.removeHandler(handler);
}
// file handler
FileHandler fh = new FileHandler(file.toString());
fh.setFormatter(new MS2Formatter());
logger.addHandler(fh);
// console handler
ConsoleHandler ch = new ConsoleHandler();
ch.setFormatter(new MS2Formatter());
logger.addHandler(ch);
logger.setLevel(Level.INFO);
编辑:回答
只是想在这里发布我的最终代码,以帮助有类似问题的任何人。
logger = Logger.getLogger("My Logger");
logger.setUseParentHandlers(false);
// remove and handlers that will be replaced
Handler[] handlers = logger.getHandlers();
for(Handler handler : handlers)
{
if(handler.getClass() == ConsoleHandler.class)
logger.removeHandler(handler);
}
// setup the file
File file = new File(location + "/" + fileName);
// file handler
FileHandler fh = new FileHandler(file.toString(), true);
fh.setFormatter(new MS2Formatter());
logger.addHandler(fh);
// console handler
ConsoleHandler ch = new ConsoleHandler();
ch.setFormatter(new MS2Formatter());
logger.addHandler(ch);
// remove and handlers that will be replaced
logger.setLevel(Level.INFO);