日志代理类LogProxy

import java.util.HashMap;
import java.util.Map;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
 * 日志代理类,在记录异常日志时,只传入一个异常对象也
 * 能直接打印异常对象栈调用信息,并加上了日志开关。
 * 
 * 但有个问题,如果log4j配置文件中的日志输出格式中有 %l
 * 时不准确,记录的不是业务调用的方法位置,而是该类调用
 * debug()、info()等方法的位置
 * @author jzj
 */
public final class LogProxy implements Log {
	/*
	 * 通用日志对象,可以是commons-logging的SimpleLog、Log4JLogger、
	 * Jdk14Logger
	 */
	private Log log;

	/*
	 * 缓存日志代理,同一种日志只创建一个代理类,与commons-logging
	 * 创建日志实例原理一样:同一种日志(按str或claz来区分)只创建一个
	 * 
	 * 多实例模式
	 */
	private static Map logMap = new HashMap();

	/*
	 * 私有构造函数
	 */
	private LogProxy() {
	}

	private LogProxy(String str) {
		log = LogFactory.getLog(str);
	}

	private LogProxy(Class claz) {
		log = LogFactory.getLog(claz);
	}

	public static synchronized LogProxy getInstance(String str) {
		LogProxy logProx = (LogProxy) logMap.get(str);
		if (logProx == null) {
			logProx = new LogProxy(str);
			logMap.put(str, logProx);
		}
		return logProx;
	}

	public static synchronized LogProxy getInstance(Class claz) {
		LogProxy logProx = (LogProxy) logMap.get(claz.getName());
		if (logProx == null) {
			logProx = new LogProxy(claz);
			logMap.put(claz.getName(), logProx);
		}
		return logProx;
	}

	public void debug(Object obj, Throwable e) {
		if (log.isDebugEnabled()) {
			log.debug(obj, e);
		}
	}

	public void debug(Object obj) {
		if (log.isDebugEnabled()) {
			if (Throwable.class.isInstance(obj)) {
				log.debug(((Throwable) obj).getMessage(), (Throwable) obj);
			} else {
				log.debug(obj);
			}
		}
	}

	public void error(Object obj, Throwable e) {
		if (log.isErrorEnabled()) {
			log.error(obj, e);
		}
	}

	public void error(Object obj) {
		if (log.isErrorEnabled()) {
			if (Throwable.class.isInstance(obj)) {
				log.error(((Throwable) obj).getMessage(), (Throwable) obj);
			} else {
				log.error(obj);
			}
		}
	}

	public void fatal(Object obj, Throwable e) {
		if (log.isFatalEnabled()) {
			log.fatal(obj, e);
		}
	}

	public void fatal(Object obj) {
		if (log.isFatalEnabled()) {
			if (Throwable.class.isInstance(obj)) {
				log.fatal(((Throwable) obj).getMessage(), (Throwable) obj);
			} else {
				log.fatal(obj);
			}
		}
	}

	public void info(Object obj, Throwable e) {
		if (log.isInfoEnabled()) {
			log.info(obj, e);
		}
	}

	public void info(Object obj) {
		if (log.isInfoEnabled()) {
			if (Throwable.class.isInstance(obj)) {
				log.info(((Throwable) obj).getMessage(), (Throwable) obj);
			} else {
				log.info(obj);
			}
		}
	}

	public void warn(Object obj, Throwable e) {
		if (log.isWarnEnabled()) {
			log.warn(obj, e);
		}
	}

	public void warn(Object obj) {
		if (log.isWarnEnabled()) {
			if (Throwable.class.isInstance(obj)) {
				log.warn(((Throwable) obj).getMessage(), (Throwable) obj);
			} else {
				log.warn(obj);
			}
		}
	}

	public boolean isDebugEnabled() {
		return log.isDebugEnabled();
	}

	public boolean isErrorEnabled() {
		return log.isErrorEnabled();
	}

	public boolean isFatalEnabled() {
		return log.isFatalEnabled();
	}

	public boolean isInfoEnabled() {
		return log.isInfoEnabled();
	}

	public boolean isTraceEnabled() {
		return log.isTraceEnabled();
	}

	public boolean isWarnEnabled() {
		return log.isWarnEnabled();
	}

	public void trace(Object arg0) {
		log.trace(arg0);
	}

	public void trace(Object arg0, Throwable arg1) {
		log.trace(arg0, arg1);
	}
}
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值