log学习之log4j1.x的使用

我爱海鲸 2022-03-08 19:13:32 暂无标签

简介日志的作用、使用、级别

1、日志介绍

用于记录系统中发生的各种事件。记录的位置常见的有:控制台、磁盘文件等

2、日志级别

日志级别从低到高:
TRACE、DEBUG、INFO、WARN、ERROR、 FATAL

3、日志作用

通过日志观察、分析项目的运行情况(项目维护)
通过日志分析用户的使用情况(大数据分析)

4、Log4j 1.x的使用

前言:在2021年12月10日凌晨log4j被JNDI的注入漏洞,影响甚大,建议使用logback,不过就算有漏洞也不影响学习

Log4j+Commons-Logging

项目中添加Log4j和Commons-Logging的依赖

        <!-- https://mvnrepository.com/artifact/log4j/log4j -->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/commons-logging/commons-logging -->
        <dependency>
            <groupId>commons-logging</groupId>
            <artifactId>commons-logging</artifactId>
            <version>1.2</version>
        </dependency>

 

创建项目:

完整的pom文件:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>xyz.haijin</groupId>
    <artifactId>log01</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <!-- https://mvnrepository.com/artifact/log4j/log4j -->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/commons-logging/commons-logging -->
        <dependency>
            <groupId>commons-logging</groupId>
            <artifactId>commons-logging</artifactId>
            <version>1.2</version>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
    </dependencies>

</project>

log4j.xml配置文件

<?xml version="1.0"  encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration PUBLIC "-//LOGGER"
        "http://org/apache/log4j/xml/log4j.dtd">
<log4j:configuration>

    <!-- org.apache.log4j.ConsoleAppender 输出到控制台 -->
    <appender name="myConsole" class="org.apache.log4j.ConsoleAppender">
        <!--输出格式-->
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern"
                   value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
        </layout>
    </appender>
    <!-- 输出到文件 -->
    <appender name="myFile1" class="org.apache.log4j.RollingFileAppender">
        <param name="File" value="d:/log/hello.log"/><!--文件位置-->
        <param name="Append" value="true"/><!--是否选择追加-->
        <param name="MaxFileSize" value="1kb"/><!--文件最大字节数-->
        <param name="MaxBackupIndex" value="2" /><!--新文件数量-->
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n" />
        </layout>
    </appender>

    <!-- 输出到文件 -->
    <appender name="myFile2" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="d:/log/world.log"/><!--文件位置-->
        <param name="Append" value="true"/><!--是否选择追加-->
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern"
                   value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
        </layout>
    </appender>
    <!-- 根logger的设置-->
    <root>
        <!--优先级设置,all < trace < debug < info < warn < error < fatal < off -->
        <priority value="all"/>
        <appender-ref ref="myConsole"/>
        <appender-ref ref="myFile1"/>
        <appender-ref ref="myFile2"/>
    </root>
</log4j:configuration>

配置文件说明:

占位符 描述
%p 输出优先级,即DEBUG, INFO, WARN, ERROR, FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符
%d 输出日志时间点的日期或时间,默认格式为IS08601,也可以在其后指定格式,比如: %dyyy-MM-dd HH:mss,SSS},输出类
似: 2002- 10-1822:10:28,921
%l 输出日志事件的发生位置,包括类名、发生的线程,以及在代码中的行数。举例: Testlo4.main(TestLog4.java:10)

LogTest.java 代码:

package xyz.haijin.log.test;

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

public class LogTest {
    // 日志对象
    private Log log = LogFactory.getLog(LogTest.class);
    @Test
    public void test1(){
        log.trace("hello trace5~~");
        log.debug("hello debug5~~");
        log.info("hello info5~~");
        log.warn("hello warn5");
        log.error("hello error5");
        log.error("hello error5");
        log.error("hello error5");
        log.error("hello error5");
        log.error("hello error5");
        log.error("hello error5");
        log.error("hello error5");
        log.error("hello error5");
        log.error("hello error5");
        log.error("hello error5");
        log.fatal("hello fatal5");
    }
}

运行结果:

你好:我的2025