我希望这个问题有一个简单的答案。我试图将记录器添加到我的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);
参考方案
您需要多少个处理程序? addHandler()将您创建的处理程序添加到与该记录器关联的处理程序中。因此,您有了默认的处理程序,并在代码中添加了两个处理程序-FileHandler和ConsoleHandler。
您可以使用getHandlers()方法获取当前的处理程序集,并使用removeHandler()删除不需要的处理程序。
在您的情况下,很有可能正在使用父处理程序。因此,即使您认为要删除处理程序,但如果您实际调试代码,您也会看到在执行for循环期间,您根本不会真正删除处理程序(或至少没有删除ConsoleHandler)。
为了防止使用父处理程序,请使用此语句。
logger.setUseParentHandlers(false);