<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FLog%2FLog_Formatter</id>
		<title>Java Tutorial/Log/Log Formatter - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FLog%2FLog_Formatter"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_Tutorial/Log/Log_Formatter&amp;action=history"/>
		<updated>2026-04-22T03:01:12Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java_Tutorial/Log/Log_Formatter&amp;diff=4274&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_Tutorial/Log/Log_Formatter&amp;diff=4274&amp;oldid=prev"/>
				<updated>2010-06-01T05:01:17Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 05:01, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java_Tutorial/Log/Log_Formatter&amp;diff=4273&amp;oldid=prev</id>
		<title> в 17:44, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_Tutorial/Log/Log_Formatter&amp;diff=4273&amp;oldid=prev"/>
				<updated>2010-05-31T17:44:27Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==  Create custom formatter ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.util.logging.ConsoleHandler;&lt;br /&gt;
import java.util.logging.Formatter;&lt;br /&gt;
import java.util.logging.Handler;&lt;br /&gt;
import java.util.logging.LogRecord;&lt;br /&gt;
import java.util.logging.Logger;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  private static Logger logger = Logger.getLogger(&amp;quot;SimpleFormatterExample&amp;quot;);&lt;br /&gt;
  private static void logMessages() {&lt;br /&gt;
    logger.info(&amp;quot;Line One&amp;quot;);&lt;br /&gt;
    logger.info(&amp;quot;Line Two&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    logger.setUseParentHandlers(false);&lt;br /&gt;
    Handler conHdlr = new ConsoleHandler();&lt;br /&gt;
    conHdlr.setFormatter(new Formatter() {&lt;br /&gt;
      public String format(LogRecord record) {&lt;br /&gt;
        return record.getLevel() + &amp;quot;  :  &amp;quot; + record.getSourceClassName() + &amp;quot; -:- &amp;quot;&lt;br /&gt;
            + record.getSourceMethodName() + &amp;quot; -:- &amp;quot; + record.getMessage() + &amp;quot;\n&amp;quot;;&lt;br /&gt;
      }&lt;br /&gt;
    });&lt;br /&gt;
    logger.addHandler(conHdlr);&lt;br /&gt;
    logMessages();&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Creating a Custom Formatter for a Logger Handler ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.util.Date;&lt;br /&gt;
import java.util.logging.FileHandler;&lt;br /&gt;
import java.util.logging.Formatter;&lt;br /&gt;
import java.util.logging.Handler;&lt;br /&gt;
import java.util.logging.Level;&lt;br /&gt;
import java.util.logging.LogRecord;&lt;br /&gt;
import java.util.logging.Logger;&lt;br /&gt;
class MyHtmlFormatter extends Formatter {&lt;br /&gt;
  public String format(LogRecord rec) {&lt;br /&gt;
    StringBuffer buf = new StringBuffer(1000);&lt;br /&gt;
    if (rec.getLevel().intValue() &amp;gt;= Level.WARNING.intValue()) {&lt;br /&gt;
      buf.append(&amp;quot;&amp;lt;b&amp;gt;&amp;quot;);&lt;br /&gt;
      buf.append(rec.getLevel());&lt;br /&gt;
      buf.append(&amp;quot;&amp;lt;/b&amp;gt;&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      buf.append(rec.getLevel());&lt;br /&gt;
    }&lt;br /&gt;
    buf.append(&amp;quot; &amp;quot;);&lt;br /&gt;
    buf.append(rec.getMillis());&lt;br /&gt;
    buf.append(&amp;quot; &amp;quot;);&lt;br /&gt;
    buf.append(formatMessage(rec));&lt;br /&gt;
    buf.append(&amp;quot;\n&amp;quot;);&lt;br /&gt;
    return buf.toString();&lt;br /&gt;
  }&lt;br /&gt;
  public String getHead(Handler h) {&lt;br /&gt;
    return &amp;quot;&amp;lt;HTML&amp;gt;&amp;lt;HEAD&amp;gt;&amp;quot; + (new Date()) + &amp;quot;&amp;lt;/HEAD&amp;gt;&amp;lt;BODY&amp;gt;&amp;lt;PRE&amp;gt;\n&amp;quot;;&lt;br /&gt;
  }&lt;br /&gt;
  public String getTail(Handler h) {&lt;br /&gt;
    return &amp;quot;&amp;lt;/PRE&amp;gt;&amp;lt;/BODY&amp;gt;&amp;lt;/HTML&amp;gt;\n&amp;quot;;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    Logger logger = Logger.getLogger(&amp;quot;com.mycompany&amp;quot;);&lt;br /&gt;
    FileHandler fh = new FileHandler(&amp;quot;mylog.html&amp;quot;);&lt;br /&gt;
    fh.setFormatter(new MyHtmlFormatter());&lt;br /&gt;
    logger.addHandler(fh);&lt;br /&gt;
    logger.setLevel(Level.ALL);&lt;br /&gt;
    logger.severe(&amp;quot;my severe message&amp;quot;);&lt;br /&gt;
    logger.info(&amp;quot;my info message&amp;quot;);&lt;br /&gt;
    logger.entering(&amp;quot;Main class&amp;quot;, &amp;quot;myMethod&amp;quot;, new Object[] { &amp;quot;para1&amp;quot;, &amp;quot;para2&amp;quot; });&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Define your own Custom Formatter ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.util.logging.Formatter;&lt;br /&gt;
import java.util.logging.LogRecord;&lt;br /&gt;
public class CustomFormatter extends Formatter {&lt;br /&gt;
  public synchronized String format(LogRecord record) {&lt;br /&gt;
    String methodName = record.getSourceMethodName();&lt;br /&gt;
    String message = record.getMessage();&lt;br /&gt;
    StringBuffer buffer = new StringBuffer(50);&lt;br /&gt;
    buffer.append(methodName);&lt;br /&gt;
    buffer.append(&amp;quot;=&amp;quot;);&lt;br /&gt;
    buffer.append(message);&lt;br /&gt;
    return buffer.toString();&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Logger with XMLFormatter and FileHandler ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.util.logging.FileHandler;&lt;br /&gt;
import java.util.logging.Handler;&lt;br /&gt;
import java.util.logging.Logger;&lt;br /&gt;
import java.util.logging.XMLFormatter;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Logger logger = Logger.getLogger(&amp;quot;my.log&amp;quot;);&lt;br /&gt;
    Handler handler = null;&lt;br /&gt;
    handler = new FileHandler(&amp;quot;messages.log&amp;quot;);&lt;br /&gt;
    logger.addHandler(handler);&lt;br /&gt;
    handler.setFormatter(new XMLFormatter());&lt;br /&gt;
    logger.info(&amp;quot;Our first logging message&amp;quot;);&lt;br /&gt;
    logger.severe(&amp;quot;Something terrible happened&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Log HTML formatter ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.util.Date;&lt;br /&gt;
import java.util.logging.FileHandler;&lt;br /&gt;
import java.util.logging.Handler;&lt;br /&gt;
import java.util.logging.Level;&lt;br /&gt;
import java.util.logging.LogManager;&lt;br /&gt;
import java.util.logging.LogRecord;&lt;br /&gt;
import java.util.logging.Logger;&lt;br /&gt;
import java.util.logging.XMLFormatter;&lt;br /&gt;
class HTMLFormatter extends java.util.logging.Formatter {&lt;br /&gt;
  public String format(LogRecord record) {&lt;br /&gt;
    return (&amp;quot;&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;&amp;quot; + (new Date(record.getMillis())).toString() + &amp;quot;&amp;lt;/td&amp;gt;&amp;lt;td&amp;gt;&amp;quot;&lt;br /&gt;
        + record.getMessage() + &amp;quot;&amp;lt;/td&amp;gt;&amp;lt;/tr&amp;gt;\n&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public String getHead(Handler h) {&lt;br /&gt;
    return (&amp;quot;&amp;lt;html&amp;gt;\n  &amp;lt;body&amp;gt;\n&amp;quot; + &amp;quot;&amp;lt;Table border&amp;gt;\n&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;Time&amp;lt;/td&amp;gt;&amp;lt;td&amp;gt;Log Message&amp;lt;/td&amp;gt;&amp;lt;/tr&amp;gt;\n&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public String getTail(Handler h) {&lt;br /&gt;
    return (&amp;quot;&amp;lt;/table&amp;gt;\n&amp;lt;/body&amp;gt;\n&amp;lt;/html&amp;gt;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
public class LoggingHTMLFormatter {&lt;br /&gt;
  public static void main(String args[]) throws Exception {&lt;br /&gt;
      LogManager lm = LogManager.getLogManager();&lt;br /&gt;
      Logger parentLogger, childLogger;&lt;br /&gt;
      FileHandler xml_handler = new FileHandler(&amp;quot;log_output.xml&amp;quot;);&lt;br /&gt;
      FileHandler html_handler = new FileHandler(&amp;quot;log_output.html&amp;quot;);&lt;br /&gt;
      parentLogger = Logger.getLogger(&amp;quot;ParentLogger&amp;quot;);&lt;br /&gt;
      childLogger = Logger.getLogger(&amp;quot;ParentLogger.ChildLogger&amp;quot;);&lt;br /&gt;
      lm.addLogger(parentLogger);&lt;br /&gt;
      lm.addLogger(childLogger);&lt;br /&gt;
      parentLogger.setLevel(Level.WARNING);&lt;br /&gt;
      childLogger.setLevel(Level.ALL);&lt;br /&gt;
      xml_handler.setFormatter(new XMLFormatter());&lt;br /&gt;
      html_handler.setFormatter(new HTMLFormatter());&lt;br /&gt;
      parentLogger.addHandler(xml_handler);&lt;br /&gt;
      childLogger.addHandler(html_handler);&lt;br /&gt;
      childLogger.log(Level.FINE, &amp;quot;This is a fine log message&amp;quot;);&lt;br /&gt;
      childLogger.log(Level.SEVERE, &amp;quot;This is a severe log message&amp;quot;);&lt;br /&gt;
      xml_handler.close();&lt;br /&gt;
      html_handler.close();&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Set log Formatter ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.util.logging.FileHandler;&lt;br /&gt;
import java.util.logging.Logger;&lt;br /&gt;
import java.util.logging.SimpleFormatter;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
  private static Logger logger = Logger.getLogger(&amp;quot;LogToFile2&amp;quot;);&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    FileHandler logFile = new FileHandler(&amp;quot;LogToFile2.txt&amp;quot;);&lt;br /&gt;
    logFile.setFormatter(new SimpleFormatter());&lt;br /&gt;
    logger.addHandler(logFile);&lt;br /&gt;
    logger.info(&amp;quot;A message logged to the file&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Setting the Formatter of a Logger Handler ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.util.logging.FileHandler;&lt;br /&gt;
import java.util.logging.Logger;&lt;br /&gt;
import java.util.logging.SimpleFormatter;&lt;br /&gt;
public class Main{&lt;br /&gt;
  public static void main(String[] argv) throws Exception{&lt;br /&gt;
    Logger logger = Logger.getLogger(&amp;quot;com.mycompany&amp;quot;);&lt;br /&gt;
    FileHandler fh = new FileHandler(&amp;quot;mylog.txt&amp;quot;);&lt;br /&gt;
    fh.setFormatter(new SimpleFormatter());&lt;br /&gt;
    logger.addHandler(fh);&lt;br /&gt;
    // fh = new FileHandler(&amp;quot;mylog.xml&amp;quot;);&lt;br /&gt;
    // fh.setFormatter(new XMLFormatter());&lt;br /&gt;
    // logger.addHandler(fh);&lt;br /&gt;
    // Log a few messages&lt;br /&gt;
    logger.severe(&amp;quot;my severe message&amp;quot;);&lt;br /&gt;
    logger.warning(&amp;quot;my warning message&amp;quot;);&lt;br /&gt;
    logger.info(&amp;quot;my info message&amp;quot;);&lt;br /&gt;
    logger.config(&amp;quot;my config message&amp;quot;);&lt;br /&gt;
    logger.fine(&amp;quot;my fine message&amp;quot;);&lt;br /&gt;
    logger.finer(&amp;quot;my finer message&amp;quot;);&lt;br /&gt;
    logger.finest(&amp;quot;my finest message&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  XMLFormatter based Logging ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.util.logging.FileHandler;&lt;br /&gt;
import java.util.logging.Level;&lt;br /&gt;
import java.util.logging.LogRecord;&lt;br /&gt;
import java.util.logging.XMLFormatter;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String args[]) throws Exception{&lt;br /&gt;
    XMLFormatter formatter = new XMLFormatter();&lt;br /&gt;
    LogRecord record = new LogRecord(Level.INFO, &amp;quot;XML message..&amp;quot;);&lt;br /&gt;
    FileHandler handler = new FileHandler(&amp;quot;newxml.xml&amp;quot;);&lt;br /&gt;
    handler.setFormatter(formatter);&lt;br /&gt;
    handler.publish(record);&lt;br /&gt;
    handler.flush();&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>