您应该扩展AppenderSkeleton类,(引用javadoc)“提供了常用功能的代码,例如支持阈值过滤和支持一般过滤器。
如果你读了AppenderSkeleton的代码,你会看到它处理几乎所有的,只留下你:
> protected void append(LoggingEvent event)
> public void close()
> public boolean requiresLayout()
核心方法是追加。记住,你不需要在其中实现过滤逻辑,因为它已经实现在doAppend,反过来调用append。
这里我做了一个(相当无用的)类,将日志条目存储在ArrayList中,就像演示一样。
public /*static*/ class MyAppender extends AppenderSkeleton {
ArrayList eventsList = new ArrayList();
@Override
protected void append(LoggingEvent event) {
eventsList.add(event);
}
public void close() {
}
public boolean requiresLayout() {
return false;
}
}
好吧,让我们来测试一下:
public static void main (String [] args) {
Logger l = Logger.getLogger("test");
MyAppender app = new MyAppender();
l.addAppender(app);
l.warn("first");
l.warn("second");
l.warn("third");
l.trace("fourth shouldn't be printed");
for (LoggingEvent le: app.eventsList) {
System.out.println("***" + le.getMessage());
}
}
你应该有“第一”,“第二”,“第三”印刷;不应该打印第四条消息,因为根记录器的日志级别是调试,而事件级别是跟踪。这证明了AbstractSkeleton为我们正确实现了“级别管理”。所以这绝对是似乎要走的路…现在的问题:为什么你需要一个自定义appender,而有很多内置的日志几乎任何目的地? (btw一个好的地方开始与log4j:http://logging.apache.org/log4j/1.2/manual.html)