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

use*_*353 4 java logging

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

这是我完整的私有 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
Run Code Online (Sandbox Code Playgroud)

这是我程序中的代码:

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");
Run Code Online (Sandbox Code Playgroud)

由于这在 2 行上给出了每个日志消息,我试过这个

如何让 java 日志输出显示在一行上?

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

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

java.util.logging.FileHandler.formatter = com.mycomp.myproj.LogFormatter;
Run Code Online (Sandbox Code Playgroud)

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

Aar*_*lla 5

我如何找出 FileHandler 不使用我的 LogFormatter 类的原因?

在调试器中启动程序并逐步执行代码。在LogManager.getLogger()和/或中设置断点LogManager.readConfiguration()

或者忘记java.util.logging并使用像logback这样的框架,它易于配置,并在出现问题时为您提供有用的错误消息。


小智 5

您可以在 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.
Run Code Online (Sandbox Code Playgroud)

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();
    }

}
Run Code Online (Sandbox Code Playgroud)

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