在JFinal2.2中引入slf4j

http://www.oschina.net/question/55156_68938?sort=time

JFinal log 目前的设计是为了让自身对第三方无依赖,在无 log4j.jar 的情况下会自动切换到 JDK logger,
slf4j 好像只是一个门面实现,对 JFinal 来说有点厚重了,JFinal 将来考虑集成最优秀的日志系统,开放配置接口,这样就可以无限支持新的 logger 了。

不能打出类的全名可能是 JDK logger 的问题, JFinal 仅仅是转调了一下 JDK logger,目前建议使用 log4j。

JFinal log 默认使用log4j,在log4j不支持情况下,自动切换的JDK logger,
在Log源码能看到;

/**
 * Log源码下5个日志级别;
 * The five logging levels used by Log are (in order):
 * 1. DEBUG (the least serious)
 * 2. INFO
 * 3. WARN
 * 4. ERROR
 * 5. FATAL (the most serious)
 */
public abstract class Log {

    private static ILogFactory defaultLogFactory = null;

    static {
        init();
    }
    // 默认使用log4j,在log4j不支持情况下,自动切换的JDK logger
    static void init() {
        if (defaultLogFactory == null) {
            try {
                Class.forName("org.apache.log4j.Logger");
                Class<?> log4jLogFactoryClass = Class.forName("com.jfinal.log.Log4jLogFactory");
                defaultLogFactory = (ILogFactory)log4jLogFactoryClass.newInstance();    // return new Log4jLogFactory();
            } catch (Exception e) {
                defaultLogFactory = new JdkLogFactory();
            }
        }
    }

    static void setDefaultLogFactory(ILogFactory defaultLogFactory) {
        if (defaultLogFactory == null) {
            throw new IllegalArgumentException("defaultLogFactory can not be null.");
        }
        Log.defaultLogFactory = defaultLogFactory;
    }

    public static Log getLog(Class<?> clazz) {
        return defaultLogFactory.getLog(clazz);
    }

    public static Log getLog(String name) {
        return defaultLogFactory.getLog(name);
    }

  .....................省略抽象方法..........................
}

在JFinal2.2中引入slf4j;

参考JFinal2.0-beetl-training

以后总结下这种框架设计

JFinal 的 Log 简单小巧。
http://www.cnblogs.com/xmsx/p/5581901.html

Jfinal2.2将 Logger 改名成 Log;

  1. 引入相应jar,或者配置pod依赖;
    2、实现slf4j插件,具体可以仿照框架中JdkLog、Log4j的实现;
    3、在configConstant中配置setLogFactory;
public class Slf4jLogFactory implements ILogFactory{

    public Log getLog(Class<?> clazz) {
        return new Slf4jLog(clazz);
    }

    public Log getLog(String name) {
        return new Slf4jLog(name);
    }

}
public class Slf4jLog extends Log {

    private org.slf4j.Logger log;

    Slf4jLog(Class<?> clazz) {
        log = LoggerFactory.getLogger(clazz);
    }

    Slf4jLog(String name) {
        log = LoggerFactory.getLogger(name);
    }

    // info、debug、warn、error、fatal;注意参数顺序
    @Override
    public void info(String message) {
        log.info(message);
    }

    @Override
    public void info(String message, Throwable t) {
        log.info(message, t);
    }

    @Override
    public void debug(String message) {
        log.debug(message);
    }

    @Override
    public void debug(String message, Throwable t) {
        log.debug(message, t);
    }

    @Override
    public void warn(String message) {
        log.warn(message);
    }

    @Override
    public void warn(String message, Throwable t) {
        log.warn(message, t);
    }

    @Override
    public void error(String message) {
        log.error(message);
    }

    @Override
    public void error(String message, Throwable t) {
        log.error(message, t);
    }

    @Override
    public void fatal(String message) {
        log.error(message);
    }

    @Override
    public void fatal(String message, Throwable t) {
        log.error(message, t);
    }

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

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

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

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

    @Override
    public boolean isFatalEnabled() {
        return log.isErrorEnabled();
    }

}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,397评论 19 139
  • 在项目开发过程中,我们可以通过 debug 查找问题。而在线上环境我们查找问题只能通过打印日志的方式查找问题。因此...
    Java架构阅读 8,804评论 2 41
  • 在应用程序中添加日志记录总的来说基于三个目的:监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析...
    时待吾阅读 10,480评论 1 13
  • 问题 在项目启动时,发现打印了大量的debug日志,但是src/main/resources下明明有log4j.x...
    Mr胡桃阅读 22,498评论 2 11
  • 因为憎恶花言巧语 所以我不懂养花种草 那些仪态万方高贵的花花草草 不适宜生长在我的院里 我的土地贫瘠,像诗歌的白纸...
    穗心说语阅读 2,338评论 3 11