6

我希望这个问题有一个简单的答案。我正在尝试将记录器添加到我的 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);
4

2 回答 2

15

您究竟需要多少个处理程序?addHandler()将您创建的处理程序添加到与该记录器关联的处理程序中。因此,您拥有了默认处理程序,以及您在代码中添加的 2 个 - FileHandler 和 ConsoleHandler。

getHandlers()您可以使用该方法获取当前的处理程序集,并用于removeHandler()删除您不需要的处理程序。

编辑

在您的情况下,可能正在使用父处理程序。因此,即使您认为您正在删除处理程序,但如果您实际调试代码,您会发现在 for 循环中执行期间您根本不会真正删除处理程序(或至少不是 ConsoleHandler)。

要防止使用父处理程序,请使用此语句。

logger.setUseParentHandlers(false);
于 2012-08-17T21:32:42.913 回答
0

在添加 ConsoleHandlers 之前,请尝试删除旧的控制台处理程序。奇怪的是,您现在以不改变原始控制台处理程序的方式登录到控制台,并且它也在链中以回显新添加的控制台处理程序的输出,因此每条消息有 3 个日志。

于 2012-08-17T21:30:34.267 回答