gpt4 book ai didi

java - 子类化 java.util.logging.Formatter 不起作用

转载 作者:塔克拉玛干 更新时间:2023-11-01 21:48:10 25 4
gpt4 key购买 nike

我正在使用 java.util.logging 进行日志记录(我不想使用 log4j 或其他任何东西)。

这是我完整的私有(private) logging.properties:

handlers= java.util.logging.FileHandler
.level= INFO
java.util.logging.FileHandler.pattern = my.log
java.util.logging.FileHandler.limit = 500000
java.util.logging.FileHandler.count = 40
java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter

这是我程序中的代码:

public static Logger log = Logger.getLogger(MyClass.class.getName());
// Is there anything else to be init'ed here?
// I don't. I just start using log directly in the code.

log.severe("something");
log.info("something else");

因为这在 2 行中给出了每条日志消息,所以我尝试了这个

How do I get java logging output to appear on a single line?

完全复制了第一个回复中的LogFormatter类。

更改了我的 logging.properties 中的一行

java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter;

现在我的日志已经开始以 XML 格式出现。我有一种强烈的感觉,FileHandler 不喜欢我的 com.mycomp.myproj.LogFormatter,因此默认为默认的 XMLFormatter。我如何弄清楚为什么 FileHandler 没有使用我的 LogFormatter 类?

最佳答案

您可以在 FileHandler 实例的代码中设置格式化程序。

import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger;

// please change name of your own choice
Logger log = Logger.getLogger("CustomLogger");
log.setUseParentHandlers(false);
log.setLevel(Level.ALL);

FileHandler handler = new FileHandler("[log_file_location]");
handler.setFormatter(new CustomFormatter()); // set formatter
log.addHandler(handler);

log.info("test message");

handler.close(); // close the handler at some later point in your application.

CustomFormatter 类定义如下。

import java.util.logging.Formatter;
import java.util.logging.LogRecord;

public class CustomFormatter extends Formatter {

@Override
public String format(LogRecord record) {
StringBuffer buffer = new StringBuffer();
buffer.append(record.getMessage());
return buffer.toString();
}

}

您可以在 CustomFormatter 中编写代码,以您想要的任何格式输出消息。希望这会有所帮助。

关于java - 子类化 java.util.logging.Formatter 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16030578/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com