log4j使用富文本JTextPane分不同颜色显示到界面

java 复制代码
package util;

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

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

public class Log4j {

    public static final Logger LOGGER = Logger.getLogger(Log4j.class);
    //配置为 界面输出 和 文件输出
    public static void configureLogger(JTextPane textPane) {
        // 创建UI界面输出的Appender
        JTextPaneAppender uiAppender = new JTextPaneAppender(textPane);
        //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"), "../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);
    }
    public static void AppendText(JTextPane textPane,String text/*文本内容*/,Color textColor/*文本颜色*/) throws BadLocationException {
        SimpleAttributeSet set = new SimpleAttributeSet();
        StyleConstants.setForeground(set, textColor);//设置文本颜色
        StyledDocument doc = textPane.getStyledDocument();
        doc.setParagraphAttributes(textPane.getText().length(), doc.getLength() - textPane.getText().length(), set, false);
        doc.insertString(doc.getLength(),text,set);
        textPane.setCaretPosition(doc.getLength());
    }
    private static class JTextPaneAppender extends AppenderSkeleton {
        private JTextPane textPane;

        public JTextPaneAppender(JTextPane textPane) {
            this.textPane = textPane;
        }

        @Override
        protected void append(LoggingEvent event) {
            Color textColor ;
            if (event.getLevel().equals(Level.DEBUG)) {
                textColor = Color.GRAY;
            } else if (event.getLevel().equals(Level.INFO)) {
                textColor = Color.BLACK;
            } else if (event.getLevel().equals(Level.WARN)) {
                textColor = Color.ORANGE;
            } else if (event.getLevel().equals(Level.ERROR)) {
                textColor = Color.RED;
            } else if (event.getLevel().equals(Level.FATAL)) {
                textColor = Color.MAGENTA;
            } else {
                textColor = Color.BLACK;
            }

            String logMessage = layout.format(event);
            SwingUtilities.invokeLater(() -> {
                try {
                    AppendText(textPane,logMessage, textColor);
                } catch (BadLocationException e) {
                    e.printStackTrace();
                }
            });
        }

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

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








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

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

        // 示例日志输出
        LOGGER.debug("Debug log message");
        LOGGER.info("Info log message");
        LOGGER.warn("Warn log message");
        LOGGER.error("Error log message chenhao");
        LOGGER.fatal("Fatal 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);

        textPane = new JTextPane();
        textPane.setEditable(false);

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

        frame.setVisible(true);
    }
}
相关推荐
Kiyra14 小时前
Query Rewrite 不是越智能越好:RAG 检索的精确词保护与动态召回
redis·websocket·junit·单元测试·json
计算机安禾17 小时前
【c++面向对象编程】第9篇:友元(friend):破坏封装的“特权”——真的有害吗?
java·c++·log4j
华万通信king17 小时前
腾讯会议API集成测试实战:从单元测试到端到端自动化
单元测试·自动化·腾讯会议
姚青&1 天前
常用的测试平台
单元测试
代码漫谈2 天前
Spring Boot日志配置全攻略:打造高效、可靠的日志系统
java·spring boot·log4j·日志
ideal-cs2 天前
总结:生产环境Logback日志配置模板与pattern格式案例
java·log4j·logback·pattern·后端日志
kyriewen2 天前
你写的代码没有测试,就像出门不锁门——Jest + Testing Library 从入门到不慌
前端·单元测试·jest
qq_435287923 天前
第19章 十绝阵:十个独立沙箱环境?阐教逐个击破的渗透测试
渗透测试·单元测试·灰度发布·防御性编程·洪荒神话·十绝阵·沙箱环境
测试员周周3 天前
【AI测试功能6】功能测试的自动化率:哪些该自动、哪些必须人工——AI测试人机协作决策指南
开发语言·人工智能·python·功能测试·单元测试·自动化·测试用例
汽车仪器仪表相关领域3 天前
Kvaser Air Bridge Light HS:免配置工业级无线 CAN 桥接器,70 米稳定传输,移动设备与动态场景的 CAN 互联理想之选
人工智能·功能测试·安全·单元测试·汽车·可用性测试