logback Converter 的一个简单的实现办法

本文介绍了如何自定义Logback的Converter,以在日志中打印调用者的类名而非logger实例的类名。通过代码实现配置,不再依赖于配置文件,简化了使用流程。只需一行代码注册自定义Converter并设置布局模式,即可实现所需功能。
摘要由CSDN通过智能技术生成

前言

原来写了一个关于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 ..

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值