Kay*_*lly 6 java formatting logging
我希望这个问题有一个简单的答案.我正在尝试将记录器添加到我的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);
Run Code Online (Sandbox Code Playgroud)
编辑:答案
只想在这里发布我的最终代码,以帮助任何有类似问题的人.
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);
Run Code Online (Sandbox Code Playgroud)
Raj*_*ani 15
你需要多少处理程序?addHandler()
将您创建的处理程序添加到与该记录器关联的处理程序.因此,您拥有默认处理程序,以及您在代码中添加的2 - FileHandler和ConsoleHandler.
您可以使用该getHandlers()
方法获取当前的处理程序集,并使用它removeHandler()
来删除您不需要的处理程序.
编辑
在您的情况下,可能正在使用父处理程序.因此,即使你认为你正在删除处理程序,如果你实际调试代码,你会发现在执行期间,在for循环中你根本不会真正删除一个处理程序(或者至少不是一个ConsoleHandler).
要防止使用父处理程序,请使用此语句.
logger.setUseParentHandlers(false);
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
8985 次 |
最近记录: |