Java Logger控制台流重复输出

我希望这个问题有一个简单的答案。 我正在尝试将记录器添加到我的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()将您创建的处理程序添加到与该记录器关联的处理程序。 所以你有了默认的处理程序,以及你在代码中添加的2 – FileHandler和ConsoleHandler。

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

编辑

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

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

 logger.setUseParentHandlers(false); 

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