2015-09-07 11:44:36 -06:00
|
|
|
// logging/CustomHandler.java
|
2015-12-15 11:47:04 -08:00
|
|
|
// (c)2016 MindView LLC: see Copyright.txt
|
2015-11-15 15:51:35 -08:00
|
|
|
// We make no guarantees that this code is fit for any purpose.
|
|
|
|
// Visit http://mindviewinc.com/Books/OnJava/ for more book information.
|
2015-06-15 17:47:35 -07:00
|
|
|
// How to write custom handler
|
2015-12-16 13:50:01 -08:00
|
|
|
// {ErrorOutputExpected}
|
2015-06-15 17:47:35 -07:00
|
|
|
import java.util.logging.*;
|
|
|
|
import java.util.*;
|
|
|
|
|
|
|
|
public class CustomHandler {
|
|
|
|
private static Logger logger =
|
|
|
|
Logger.getLogger("CustomHandler");
|
|
|
|
private static List<String> trace =
|
|
|
|
new ArrayList<>();
|
|
|
|
public static void main(String[] args) {
|
|
|
|
logger.addHandler(new Handler() {
|
|
|
|
@Override
|
|
|
|
public void publish(LogRecord logRecord) {
|
|
|
|
trace.add(logRecord.getLevel() + ":");
|
|
|
|
trace.add(logRecord.getSourceClassName()
|
|
|
|
+ ":");
|
|
|
|
trace.add(
|
|
|
|
logRecord.getSourceMethodName() +":");
|
|
|
|
trace.add("<" + logRecord.getMessage()
|
|
|
|
+ ">");
|
|
|
|
trace.add("\n");
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public void flush() {}
|
|
|
|
@Override
|
|
|
|
public void close() {}
|
|
|
|
});
|
|
|
|
logger.warning("Logging Warning");
|
|
|
|
logger.info("Logging Info");
|
|
|
|
System.out.print(trace);
|
|
|
|
}
|
2015-09-07 11:44:36 -06:00
|
|
|
}
|
|
|
|
/* Output:
|
2015-06-15 17:47:35 -07:00
|
|
|
[WARNING:, CustomHandler:, main:, <Logging Warning>,
|
|
|
|
, INFO:, CustomHandler:, main:, <Logging Info>,
|
|
|
|
]
|
|
|
|
___[ Error Output ]___
|
2016-07-27 11:12:11 -06:00
|
|
|
Jul 27, 2016 10:50:39 AM CustomHandler main
|
2015-06-15 17:47:35 -07:00
|
|
|
WARNING: Logging Warning
|
2016-07-27 11:12:11 -06:00
|
|
|
Jul 27, 2016 10:50:39 AM CustomHandler main
|
2015-06-15 17:47:35 -07:00
|
|
|
INFO: Logging Info
|
2015-09-07 11:44:36 -06:00
|
|
|
*/
|