验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

Java Logger日志格式怎么自定义

阅读:204 来源:乙速云 作者:代码code

Java Logger日志格式怎么自定义

在Java中,可以使用java.util.logging.Logger类和java.util.logging.Formatter接口来自定义日志格式。以下是一个简单的示例,展示了如何自定义日志格式:

  1. 首先,创建一个实现java.util.logging.Formatter接口的类,例如MyFormatter:
import java.util.logging.Formatter;
import java.util.logging.LogRecord;

public class MyFormatter extends Formatter {

    @Override
    public String format(LogRecord record) {
        StringBuilder sb = new StringBuilder();
        
        // 获取日志级别
        sb.append("[");
        sb.append(record.getLevel().getName());
        sb.append("] ");
        
        // 获取日志时间戳
        sb.append(new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS").format(new Date(record.getMillis())));
        
        // 获取日志消息
        sb.append(" - ");
        sb.append(record.getMessage());
        
        // 获取异常信息(如果有)
        if (record.getThrown() != null) {
            sb.append("n");
            sb.append(getStackTraceString(record.getThrown()));
        }
        
        return sb.toString();
    }

    private String getStackTraceString(Throwable throwable) {
        StringWriter sw = new StringWriter();
        PrintWriter pw = new PrintWriter(sw);
        throwable.printStackTrace(pw);
        return sw.toString();
    }
}
  1. 然后,在需要使用自定义日志格式的地方,设置Logger的Formatter:
import java.util.logging.Level;
import java.util.logging.Logger;

public class Main {
    private static final Logger logger = Logger.getLogger(Main.class.getName());

    public static void main(String[] args) {
        // 设置自定义Formatter
        MyFormatter myFormatter = new MyFormatter();
        ConsoleHandler consoleHandler = new ConsoleHandler();
        consoleHandler.setFormatter(myFormatter);
        logger.addHandler(consoleHandler);
        logger.setLevel(Level.ALL);

        // 使用Logger记录日志
        logger.info("这是一条INFO级别的日志");
        logger.warning("这是一条WARNING级别的日志");
        logger.severe("这是一条SEVERE级别的日志");
    }
}

运行上述代码,你将在控制台看到自定义格式的日志输出。你可以根据自己的需求修改MyFormatter类中的format方法,以实现所需的日志格式。

分享到:
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
相关文章
{{ v.title }}
{{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
你可能感兴趣
推荐阅读 更多>