java 使用log4j显示到界面和文件 并格式化

1.下载log4j

jar包https://dlcdn.apache.org/logging/log4j/2.20.0/apache-log4j-2.20.0-bin.zip

2. 我只要到核心包 ,看需要

sources是源码包,可以看到说明。在IDEA里先加入class jar后,再双击这个class jar包或或右键选Navigate ,Add ,选对应的Sources.jar

3.示例代码

java 复制代码
package util;

import org.apache.log4j.*;
import org.apache.log4j.spi.LoggingEvent;

import javax.swing.*;
import java.awt.*;
import java.io.*;

public class Log4j {
    public static final Logger LOGGER = Logger.getLogger(Log4j.class);



    private static JTextArea textArea;
    public static void main(String[] args) {
        // 创建并显示UI界面
        createUI();

        // 配置log4j日志记录器
        configureLogger(textArea);

        // 示例日志输出
        LOGGER.debug("Debug log message");
        LOGGER.info("Info log message");
        LOGGER.warn("Warn log message");
        LOGGER.error("Error log message chenhao");

        // 关闭log4j日志记录器
        LogManager.shutdown();
    }

    private static void createUI() {
        JFrame frame = new JFrame("Log Example");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.setSize(400, 300);

        textArea = new JTextArea();
        textArea.setEditable(false);

        JScrollPane scrollPane = new JScrollPane(textArea);
        frame.getContentPane().add(scrollPane, BorderLayout.CENTER);

        frame.setVisible(true);
    }

    //配置为 界面输出 和 文件输出
    public static void configureLogger(JTextArea textArea) {
        // 创建UI界面输出的Appender
        JTextAreaAppender uiAppender = new JTextAreaAppender(textArea);
        //uiAppender.setLayout(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss} %c [%p] - %m%n"));
        uiAppender.setLayout(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss} [%p] - %m%n"));
        uiAppender.activateOptions();
        Logger.getRootLogger().addAppender(uiAppender);

        // 创建文件输出的Appender
        try {
            FileAppender fileAppender = new FileAppender(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss} [%p] - %m%n"), "logs/logfile.log");
            fileAppender.setAppend(true); // 如果true,则追加到现有的日志文件末尾;如果false,则覆盖文件中的现有内容
            fileAppender.activateOptions();
            // 将Appender添加到日志记录器
            Logger.getRootLogger().addAppender(fileAppender);
        } catch (IOException e) {
            e.printStackTrace();
            return;
        }

        // 设置日志记录级别
        LOGGER.setLevel(Level.DEBUG);
    }
    //配置为 控制台输出 和 文件输出
    public static void configureLogger() {
        // 创建控制台输出的Appender
        ConsoleAppender consoleAppender = new ConsoleAppender();
        consoleAppender.setLayout(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss} %c [%p] - %m%n"));
        consoleAppender.setTarget(ConsoleAppender.SYSTEM_OUT);
        consoleAppender.activateOptions();

        // 创建文件输出的Appender
        try {
            FileAppender fileAppender = new FileAppender(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss} %c [%p] - %m%n"), "logs/logfile.log");
            fileAppender.setAppend(true); // 如果true,则追加到现有的日志文件末尾;如果false,则覆盖文件中的现有内容
            fileAppender.activateOptions();
            // 将Appender添加到日志记录器
            Logger.getRootLogger().addAppender(fileAppender);
        } catch (IOException e) {
            e.printStackTrace();
            return;
        }

        // 设置日志记录级别
        LOGGER.setLevel(Level.DEBUG);
    }

    private static class JTextAreaAppender extends AppenderSkeleton {
        private JTextArea textArea;

        public JTextAreaAppender(JTextArea textArea) {
            this.textArea = textArea;
        }

        @Override
        protected void append(LoggingEvent loggingEvent) {
            String logMessage = layout.format(loggingEvent);
            SwingUtilities.invokeLater(() -> textArea.append(logMessage));
        }

        @Override
        public void close() {
            // Nothing to do here
        }

        @Override
        public boolean requiresLayout() {
            return true;
        }
    }
}

4.格式化

解释一下"%d{yyyy-MM-dd HH:mm:ss} %c [%p] - %m%n"每个部分的含义:

  • %d{yyyy-MM-dd HH:mm:ss}:表示输出日志的时间戳,使用指定的日期时间格式("yyyy-MM-dd HH:mm:ss")。

  • %c:表示输出日志的类名。

  • [%p]:表示输出日志的级别(例如,DEBUG、INFO、WARN、ERROR)。

  • -%m:表示输出日志的消息。

  • %n:表示换行符。

相关推荐
范什么特西2 分钟前
idea创建一个普通的Maven项目运行javaweb
java·maven·intellij-idea
好家伙VCC8 分钟前
# 发散创新:用 Rust实现高性能物理引擎的底层架构设计与实战在游戏开发、虚拟仿真和机器人控
java·开发语言·python·rust·机器人
六道对穿肠9 分钟前
Java 直连 USB 打印机实战:从 JNI 崩溃到「拷贝即用」的架构演进
java
boonya17 分钟前
一文读懂MCP:AI连接万物的“USB-C接口”
c语言·开发语言·人工智能
liliangcsdn19 分钟前
多轮对话长上下文-向量检索和混合召回示例
开发语言·数据库·人工智能·python
user_admin_god19 分钟前
OpenCode入门到入坑
java·人工智能·spring boot·语言模型
Maiko Star20 分钟前
Claude Code安装教程
java·chatgpt·claude code
leoZ23122 分钟前
金仓老旧项目改造-10
开发语言·前端·人工智能·python·金仓
故事和你9125 分钟前
洛谷-数据结构1-1-线性表2
开发语言·数据结构·算法·动态规划·图论
小徐不徐说29 分钟前
面试C++易错点总结
开发语言·c++·面试·职场和发展·程序设计·工作