xmllog4jconfig.xml 如下:
<?xml version="1.0" encoding="utf-8" ?>
<!doctype log4j:configuration system "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="appender" class="org.apache.log4j.fileappender">
<param name="file" value="indentify-log.txt"/>
<param name="append" value="false"/>
<layout class="org.apache.log4j.patternlayout">
<param name="conversionpattern" value="%d [%t] %p - %m%n"/>
</layout>
</appender>
<root>
<priority value ="debug"/>
<appender-ref ref="appender"/>
</root>
</log4j:configuration>
對比properties方式和xml方式,可以看出他們程式中,除了定義讀取配置檔案的方式不同外,其它的根本就沒
有差別了,這也就是log4j的魅力所在了,不需要改變程式,隻需要通過改變定義的配置檔案,我們就可以控制日志的輸
出方式,是否輸出,輸出格式。我們可以通過定義不同的xml檔案來控制輸出方式.以下是各種輸出方式與布局的例子。
4.2.3 比較簡單的一個。
<?xml version="1.0" encoding="gb2312" ?>
<!--
配置輸出的日志目錄為在控制台。
格式采用為patternloyout,并且樣式為:%d{iso8601} %r [%c :: %p %m]%n
-->
<appender name="ca" class="org.apache.log4j.consoleappender">
<param name="conversionpattern" value="%d{iso8601} %r [%c :: %p %m]%n"/>
<appender-ref ref="ca"/>
4.2.4 檔案的輸出 pattern的布局
<param name="conversionpattern" value="%d [%t] %p - %m%n"/>
<appender-ref ref="appender"/>
4.2.5 控制台的輸出 和簡單的布局
<appender name="consoleappender" class="org.apache.log4j.consoleappender">
<layout class="org.apache.log4j.simplelayout"/>
<priority value ="debug" />
<appender-ref ref="consoleappender"/>
4.2.6 定義三種輸出方式,按照不同的級别,選擇不同的輸出方式.debug,info,級别通過system.out來列印。
warn,fatal通過system.err來輸出。error,fatal發送到郵箱。
<log4j:configuration>
<appender name="stdout" class="org.apache.log4j.consoleappender">
<param name="target" value="system.out" />
<layout class="org.apache.log4j.patternlayout">
<param name="conversionpattern" value="[%d{iso8601}] %-5p %c %m %n" />
</layout>
<filter class="org.apache.log4j.varia.levelrangefilter">
<param name="levelmin" value="debug"/>
<param name="levelmax" value="info"/>
</filter>
</appender>
<appender name="stderr" class="org.apache.log4j.consoleappender">
<param name="target" value="system.err" />
<param name="levelmin" value="warn"/>
<param name="levelmax" value="fatal"/>
<!-- -->
<!-- declare the smtpappender -->
<appender name="email" class="org.apache.log4j.net.smtpappender">
<param name="buffersize" value="512" />
<param name="smtphost" value="mail.suiyuanwu.com" />
<param name="from" value="log4j@server5" />
<param name="to" value="[email protected]" />
<param name="subject" value="[smtpappender] application message" />
<param name="conversionpattern" value="[%d{iso8601}]%n%n%-5p%n%n%c%n%n%m%n%n" />
</layout>
<param name="levelmin" value="error"/>
<param name="levelmax" value="fatal"/>
<!-- -->
<!-- setup log4js root logger -->
<root>
<level value="all" />
<appender-ref ref="stdout"/>
<appender-ref ref="stderr"/>
<appender-ref ref="email" />
</root>
五、參考資料
1.http://www.vipan.com/htdocs/log4jhelp.html
dont use system.out.println! use log4j - vipan singla
2.http://jakarta.apache.org/log4j/docs/manual.html
short introduction to log4j - ceki gülcü - march 2002
3.http://www-128.ibm.com/developerworks/cn/java/jw-log4j/
log4j提供了對日志記錄的控制
4.http://logging.apache.org/log4j/docs/documentation.html
log4j提供的文檔。
轉帖自:http://jakarta.apache.org/log4j/ xml