前言
原来写了一个关于logback 的源码阅读与自定义自己的Converter 的实现方法。但是太基于配置文件了。要是脱离了配置文件反而不好使了。
其实很简单。略改以后完事。
实现过程
还是说一下原来的那个事
前文 >>>>>>>>>>> logback 自定义 Layout
需要自定义一个Converter 或者说修改原来的Converter 实现办法。以及对logger的再次封装。
好吧我自己定义一个Converter
代码如下
public class LogClassOfCallerConverter extends NamedConverter {
/*
就是当嵌套封装调用时候不显示logger实际的类而是 显示被调用的类名称。
当不是调用封装的时候 显示自己实际的类
分析一下。其实就是多一层调用就多一层堆栈。就是从执行方法到main的一个执行调用关系。那么取最上层或者第二层就好了。
顺道将CML 这三个Converter 进行组合。
*/
protected String getFullyQualifiedName(ILoggingEvent event) {
StackTraceElement[] cda = event.getCallerData();
if (cda != null && cda.length > 1) {
return cda[1].getClassName()+"|"+cda[1].getMethodName()+"|"+Integer.toString(cda[1].getLineNumber());
}
else if (cda != null && cda.length == 1)
{
return cda[0].getClassName()+"|"+cda[0].getMethodName()+"|"+Integer.toString(cda[0].getLineNumber());
}
else {
return CallerData.NA;
}
}
}
这个Converter 搞完以后那么原来的话还要指定layout什么的。再通过配置文件指定。
现在完全不需要了。
只需要一行代码就行了
PatternLayout.defaultConverterMap.put("CML", LogClassOfCallerConverter.class.getName());
我将自定义的这个组合名字定义为CML
使用的话设置 为%CML 就好了
去配置 ,直接代码实现logback 配置
一个简单例子:
不用配置文件直接自己怼一下代码直接
public static void main(String a[]) {
//加入自己的converter
PatternLayout.defaultConverterMap.put("CML", LogClassOfCallerConverter.class.getName());
//获取context
LoggerContext logf = (LoggerContext) LoggerFactory.getILoggerFactory();
// 设置样式
PatternLayoutEncoder encoder = new PatternLayoutEncoder();
encoder.setPattern("%date{dd-MM-yy HH:mm:ss.SSS}|%level|%thread|%logger|%CML|%msg%n");
encoder.setContext(logf);
encoder.start();
// 再关联
ConsoleAppender<ILoggingEvent> ca = new ConsoleAppender<>();
ca.setEncoder(encoder);
ca.setContext(logf);
ca.start();
// 使用
Logger log = logf.getLogger("TEST");
log.setAdditive(false);
log.addAppender(ca);
log.info("test ..");
}
注意 PatternLayout.defaultConverterMap.put 直接 向defaultConverterMap put自己定义好的converter就好了。
还有注意对于Pattern 的设置 %CML
输出结果:
20-07-21 18:11:41.676|INFO|main|TEST|examples.logs.ELog|main|37|test ..