[英]Subclassing java.util.logging.Formatter doesn't work
我正在使用java.util.logging
进行日志记录(我不想使用 log4j 或其他任何东西)。
这是我完整的私有 logging.properties:
handlers= java.util.logging.FileHandler
.level= INFO
java.util.logging.FileHandler.pattern = my.log
java.util.logging.FileHandler.limit = 500000
java.util.logging.FileHandler.count = 40
java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter
这是我程序中的代码:
public static Logger log = Logger.getLogger(MyClass.class.getName());
// Is there anything else to be init'ed here?
// I don't. I just start using log directly in the code.
log.severe("something");
log.info("something else");
因为这会在 2 行中给出每条日志消息,所以我尝试了这个
准确复制第一个回复中的LogFormatter class。
更改了我的 logging.properties 中的一行
java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter;
现在我的日志开始出现在 XML 中。我有一种强烈的感觉,即FileHandler
不喜欢我的com.mycomp.myproj.LogFormatter
,因此默认为默认的XMLFormatter
。 我如何弄清楚为什么FileHandler
没有使用我的 LogFormatter class?
我如何弄清楚为什么FileHandler没有使用我的LogFormatter类?
在调试器中启动程序并逐步执行代码。 在LogManager.getLogger()
和/或LogManager.readConfiguration()
设置断点
或者忘记java.util.logging
并使用易于配置的logback这样的框架,并在出现问题时为您提供有用的错误消息。
您可以在FileHandler实例上的代码本身中设置格式化程序。
import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger;
// please change name of your own choice
Logger log = Logger.getLogger("CustomLogger");
log.setUseParentHandlers(false);
log.setLevel(Level.ALL);
FileHandler handler = new FileHandler("[log_file_location]");
handler.setFormatter(new CustomFormatter()); // set formatter
log.addHandler(handler);
log.info("test message");
handler.close(); // close the handler at some later point in your application.
CustomFormatter类定义如下。
import java.util.logging.Formatter;
import java.util.logging.LogRecord;
public class CustomFormatter extends Formatter {
@Override
public String format(LogRecord record) {
StringBuffer buffer = new StringBuffer();
buffer.append(record.getMessage());
return buffer.toString();
}
}
您可以在CustomFormatter中编码,以您想要的任何格式输出消息。 希望这可以帮助。
好吧,这个也让我非常恼火,并且让我疯狂,我正在无休止地检查拼写,进行谷歌搜索等 - 这就是我到达这里的方式 - 我知道这是一年之久,但你要踢自己。 这是我非常肯定你的答案。
用于:
java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter;
那应该是:
java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter
放弃训练“;”。 它似乎需要与我看到别人抱怨他们有空白字符的类名完全匹配 - 这就是我的问题所在。 更好的错误消息会有所帮助。
干杯 - 马克
com.mycomp.myproj.LogFormatter不在您的系统类路径中。
LogManager将执行以下调用来加载您的类:
Formatter getFormatterProperty(String name, Formatter defaultValue) {
String val = getProperty(name);
try {
if (val != null) {
Class<?> clz = ClassLoader.getSystemClassLoader().loadClass(val);
return (Formatter) clz.newInstance();
}
} catch (Exception ex) {
// We got one of a variety of exceptions in creating the
// class or creating an instance.
// Drop through.
}
// We got an exception. Return the defaultValue.
return defaultValue;
}
您需要确保您的类LogFormatter位于系统的类路径中。
我发现除非你通过配置设置格式,否则它不适用于格式化程序。 我在JDK 11上测试了这个。
handlers= java.util.logging.FileHandler
.level= INFO
java.util.logging.FileHandler.pattern = my.log
java.util.logging.FileHandler.limit = 500000
java.util.logging.FileHandler.count = 40
java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter
com.mycomp.myproj.LogFormatter.format = %n
即添加最后一行com.mycomp.myproj.LogFormatter.format = %n
可能这在这一点上不相关,但最近我发现一个问题,格式中的$导致我出现问题,它无法解析并退回到默认格式。 本来我有
[%1$tF %1$tT] [%4$-7s] %5$s %n
在logging.properties文件中,它没有按预期工作,但是
[%1\$tF %1\$tT] [%4\$-7s] %5\$s %n
这与\$
完美配合。 将来可能会对其他人有所帮助。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.