JFinal学习--01日志

本文详细探讨了JFinal框架中日志系统的实现原理,包括抽象工厂模式的应用、日志包的组织结构以及如何配置日志系统。重点介绍了JdkLog和Log4jLog两种日志实现方式,并通过实例展示了如何在实际项目中灵活运用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JFinal是框架中最基础的部分之一,提供了JdkLog和Log4jLog两种,默认情况下使用的是Log4jLog。

日志的包是com.jfinal.log,如下图

这里写图片描述

日志使用了抽象工厂模式,如下图
这里写图片描述

Log类是一个抽象类,其中定义了日志需要用到的公共抽象方法。另外,还定义了一个defaultLogFactory静态属性(继承了ILogFactory接口),这个属性在类的static模块中进行了赋值。

    static {
        init();
    }

    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();
            }
        }
    }

最后,LogManager的作用是用来启动日志用的,它在com.jfinal.core.Config类中用到:

    private static void initLogFactory() {
        LogManager.me().init();
        log = Log.getLog(Config.class);
        JFinalFilter.initLog();
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值