我是 log4j 的新手。谁能解释如何创建我自己的 Appender?即如何实现类和接口以及如何覆盖它?
原文由 unknown 发布,翻译遵循 CC BY-SA 4.0 许可协议
如果你想做一些操作或决定,你可以这样做:
@Override
protected void append(LoggingEvent event) {
String message = null;
if(event.locationInformationExists()){
StringBuilder formatedMessage = new StringBuilder();
formatedMessage.append(event.getLocationInformation().getClassName());
formatedMessage.append(".");
formatedMessage.append(event.getLocationInformation().getMethodName());
formatedMessage.append(":");
formatedMessage.append(event.getLocationInformation().getLineNumber());
formatedMessage.append(" - ");
formatedMessage.append(event.getMessage().toString());
message = formatedMessage.toString();
}else{
message = event.getMessage().toString();
}
switch(event.getLevel().toInt()){
case Level.INFO_INT:
//your decision
break;
case Level.DEBUG_INT:
//your decision
break;
case Level.ERROR_INT:
//your decision
break;
case Level.WARN_INT:
//your decision
break;
case Level.TRACE_INT:
//your decision
break;
default:
//your decision
break;
}
}
原文由 Lior 发布,翻译遵循 CC BY-SA 3.0 许可协议
15 回答8.4k 阅读
8 回答6.2k 阅读
1 回答4k 阅读✓ 已解决
3 回答6k 阅读
3 回答2.2k 阅读✓ 已解决
2 回答3.1k 阅读
2 回答3.8k 阅读
更新:提供的解决方案对 Log4J 1.x 有效。如果您正在寻找 2.x 版本,请查看这篇文章: How to create a custom appender in log4j2
您应该扩展 AppenderSkeleton 类,它(引用 javadoc)“提供通用功能的代码,例如支持阈值过滤和支持一般过滤器。”
如果您阅读 AppenderSkeleton 的代码,您会发现它几乎可以处理所有问题,只剩下:
核心方法是append。请记住,您不需要在其中实现过滤逻辑,因为它已经在 doAppend 中实现,而 doAppend 又会调用 append。在这里,我做了一个(非常无用的)类,将日志条目存储在 ArrayList 中,就像一个演示。
好的,让我们测试一下:
你应该打印“第一”、“第二”、“第三”;不应打印第四条消息,因为根记录器的日志级别是调试,而事件级别是跟踪。这证明AbstractSkeleton为我们正确地实现了“层级管理”。所以这绝对是可行的方法……现在的问题是:为什么您需要自定义附加程序,而该日志中有许多内置程序几乎可以到达任何目的地? (顺便说一句,开始使用 log4j 的好地方:http: //logging.apache.org/log4j/1.2/manual.html )