from:http://coderdream.iteye.com/blog/378077
两个必要步骤执行完毕,您就可以轻松地使用不同优先级别的日志记录语句插入到您想记录日志的任何地方,其语法如下:
Logger.debug ( Object message ) ;
Logger.info ( Object message ) ;
Logger.warn ( Object message ) ;
Logger.error ( Object message ) ;
示例2~示例8
【示例2】 输出为文本文件或HTML文件
- #设置级别:
- log4j.rootLogger=debug,appender1
- #输出到文件(这里默认为追加方式)
- log4j.appender.appender1=org.apache.log4j.FileAppender
- #设置文件输出路径
- #【1】文本文件
- #log4j.appender.appender1.File=c:/Log4JDemo02.log
- #【2】HTML文件
- log4j.appender.appender1.File=c:/Log4JDemo02.html
- #设置文件输出样式
- #log4j.appender.appender1.layout=org.apache.log4j.TTCCLayout
- log4j.appender.appender1.layout=org.apache.log4j.HTMLLayout
#设置级别: log4j.rootLogger=debug,appender1 #输出到文件(这里默认为追加方式) log4j.appender.appender1=org.apache.log4j.FileAppender #设置文件输出路径 #【1】文本文件 #log4j.appender.appender1.File=c:/Log4JDemo02.log #【2】HTML文件 log4j.appender.appender1.File=c:/Log4JDemo02.html #设置文件输出样式 #log4j.appender.appender1.layout=org.apache.log4j.TTCCLayout log4j.appender.appender1.layout=org.apache.log4j.HTMLLayout
【 示例3】 输出为文本文件或HTML文件
- #设置级别和多个目的地
- log4j.rootLogger=debug,appender1,appender2
- #输出到控制台
- log4j.appender.appender1=org.apache.log4j.ConsoleAppender
- #设置输出样式
- log4j.appender.appender1.layout=org.apache.log4j.TTCCLayout
- #输出到文件(这里默认为追加方式)
- log4j.appender.appender2=org.apache.log4j.FileAppender
- #设置文件输出路径
- #【1】文本文件
- #log4j.appender.appender2.File=c:/Log4JDemo02.log
- #【2】HTML文件
- log4j.appender.appender2.File=c:/Log4JDemo02.html
- #设置文件输出样式
- #log4j.appender.appender2.layout=org.apache.log4j.TTCCLayout
- log4j.appender.appender2.layout=org.apache.log4j.HTMLLayout
#设置级别和多个目的地 log4j.rootLogger=debug,appender1,appender2 #输出到控制台 log4j.appender.appender1=org.apache.log4j.ConsoleAppender #设置输出样式 log4j.appender.appender1.layout=org.apache.log4j.TTCCLayout #输出到文件(这里默认为追加方式) log4j.appender.appender2=org.apache.log4j.FileAppender #设置文件输出路径 #【1】文本文件 #log4j.appender.appender2.File=c:/Log4JDemo02.log #【2】HTML文件 log4j.appender.appender2.File=c:/Log4JDemo02.html #设置文件输出样式 #log4j.appender.appender2.layout=org.apache.log4j.TTCCLayout log4j.appender.appender2.layout=org.apache.log4j.HTMLLayout
【示例4】 SimpleLayout样式
- #设置级别和目的地
- log4j.rootLogger=debug,appender1
- #输出到控制台
- log4j.appender.appender1=org.apache.log4j.ConsoleAppender
- #设置输出样式
- log4j.appender.appender1.layout=org.apache.log4j.SimpleLayout
#设置级别和目的地 log4j.rootLogger=debug,appender1 #输出到控制台 log4j.appender.appender1=org.apache.log4j.ConsoleAppender #设置输出样式 log4j.appender.appender1.layout=org.apache.log4j.SimpleLayout
输出结果:
- DEBUG - This is debug message.
- INFO - This is info message.
- ERROR - This is error message.
DEBUG - This is debug message. INFO - This is info message. ERROR - This is error message.
【示例5】 自定义样式
- #设置级别和目的地
- log4j.rootLogger=debug,appender1
- #输出到控制台
- log4j.appender.appender1=org.apache.log4j.ConsoleAppender
- #设置输出样式
- log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
- #自定义样式
- # %r 时间 0
- # %t 方法名 main
- # %p 优先级 DEBUG/INFO/ERROR
- # %c 所属类的全名(包括包名)
- # %l 发生的位置,在某个类的某行
- # %m 输出代码中指定的讯息,如log(message)中的message
- # %n 输出一个换行
- log4j.appender.appender1.layout.ConversionPattern=%r [%t] [%p] - %c -%l -%m%n
#设置级别和目的地
log4j.rootLogger=debug,appender1
#输出到控制台
log4j.appender.appender1=org.apache.log4j.ConsoleAppender
#设置输出样式
log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
#自定义样式
# %r 时间 0
# %t 方法名 main
# %p 优先级 DEBUG/INFO/ERROR
# %c 所属类的全名(包括包名)
# %l 发生的位置,在某个类的某行
# %m 输出代码中指定的讯息,如log(message)中的message
# %n 输出一个换行
log4j.appender.appender1.layout.ConversionPattern=%r [%t] [%p] - %c -%l -%m%n
输出结果:
- 0 [main] [DEBUG] - com.coderdream.log4j.HelloLog4j
- -com.coderdream.log4j.HelloLog4j.main(HelloLog4j.java:16) -This is debug message.
- 31 [main] [INFO] - com.coderdream.log4j.HelloLog4j
- -com.coderdream.log4j.HelloLog4j.main(HelloLog4j.java:18) -This is info message.
- 31 [main] [ERROR] - com.coderdream.log4j.HelloLog4j
- -com.coderdream.log4j.HelloLog4j.main(HelloLog4j.java:20) -This is error message.
0 [main] [DEBUG] - com.coderdream.log4j.HelloLog4j -com.coderdream.log4j.HelloLog4j.main(HelloLog4j.java:16) -This is debug message. 31 [main] [INFO] - com.coderdream.log4j.HelloLog4j -com.coderdream.log4j.HelloLog4j.main(HelloLog4j.java:18) -This is info message. 31 [main] [ERROR] - com.coderdream.log4j.HelloLog4j -com.coderdream.log4j.HelloLog4j.main(HelloLog4j.java:20) -This is error message.
【示例6】 多目的地、自定义样式
- #设置级别和目的地
- log4j.rootLogger=debug,appender1,appender2
- #输出到控制台
- log4j.appender.appender1=org.apache.log4j.ConsoleAppender
- #设置输出样式
- log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
- #自定义样式
- # %r 时间 0
- # %t 方法名 main
- # %p 优先级 DEBUG/INFO/ERROR
- # %c 所属类的全名(包括包名)
- # %l 发生的位置,在某个类的某行
- # %m 输出代码中指定的讯息,如log(message)中的message
- # %n 输出一个换行符号
- log4j.appender.appender1.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%C-%M] %m%n
- #输出到文件(这里默认为追加方式)
- log4j.appender.appender2=org.apache.log4j.FileAppender
- #设置文件输出路径
- #【1】文本文件
- log4j.appender.appender2.File=c:/Log4JDemo06.log
- #设置文件输出样式
- log4j.appender.appender2.layout=org.apache.log4j.PatternLayout
- log4j.appender.appender2.layout.ConversionPattern=[%d{HH:mm:ss:SSS}][%C-%M] -%m%n
#设置级别和目的地 log4j.rootLogger=debug,appender1,appender2 #输出到控制台 log4j.appender.appender1=org.apache.log4j.ConsoleAppender #设置输出样式 log4j.appender.appender1.layout=org.apache.log4j.PatternLayout #自定义样式 # %r 时间 0 # %t 方法名 main # %p 优先级 DEBUG/INFO/ERROR # %c 所属类的全名(包括包名) # %l 发生的位置,在某个类的某行 # %m 输出代码中指定的讯息,如log(message)中的message # %n 输出一个换行符号 log4j.appender.appender1.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%C-%M] %m%n #输出到文件(这里默认为追加方式) log4j.appender.appender2=org.apache.log4j.FileAppender #设置文件输出路径 #【1】文本文件 log4j.appender.appender2.File=c:/Log4JDemo06.log #设置文件输出样式 log4j.appender.appender2.layout=org.apache.log4j.PatternLayout log4j.appender.appender2.layout.ConversionPattern=[%d{HH:mm:ss:SSS}][%C-%M] -%m%n
【示例7】 【企业应用】设置 特定包的级别和目的地
先增加一个包,新建一个类:
- package com.coderdream.log4jDao;
- import org.apache.log4j.Logger;
- public class HelloDao {
- private static Logger logger = Logger.getLogger(HelloDao.class);
- /**
- * @param args
- */
- public static void main(String[] args) {
- // 记录debug级别的信息
- logger.debug("This is debug message from Dao.");
- // 记录info级别的信息
- logger.info("This is info message from Dao.");
- // 记录error级别的信息
- logger.error("This is error message from Dao.");
- }
- }
package com.coderdream.log4jDao;
import org.apache.log4j.Logger;
public class HelloDao {
private static Logger logger = Logger.getLogger(HelloDao.class);
/**
* @param args
*/
public static void main(String[] args) {
// 记录debug级别的信息
logger.debug("This is debug message from Dao.");
// 记录info级别的信息
logger.info("This is info message from Dao.");
// 记录error级别的信息
logger.error("This is error message from Dao.");
}
}
如果这个类作为基类,如J2EE中的BaseDao、BaseAction、BaseService等等,则我们可以将各层的日志信息分类输出到各个文件。
- #省略根,只设置特定包的级别和目的地
- log4j.logger.com.coderdream.log4j=debug,appender1
- log4j.logger.com.coderdream.log4jDao=info,appender1,appender2
- #输出到控制台
- log4j.appender.appender1=org.apache.log4j.ConsoleAppender
- #设置输出样式
- log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
- #自定义样式
- # %r 时间 0
- # %t 方法名 main
- # %p 优先级 DEBUG/INFO/ERROR
- # %c 所属类的全名(包括包名)
- # %l 发生的位置,在某个类的某行
- # %m 输出代码中指定的讯息,如log(message)中的message
- # %n 输出一个换行符号
- log4j.appender.appender1.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%C-%M] %m%n
- #输出到文件(这里默认为追加方式)
- log4j.appender.appender2=org.apache.log4j.FileAppender
- #设置文件输出路径
- #【1】文本文件
- log4j.appender.appender2.File=c:/Log4JDemo07_Dao.log
- #设置文件输出样式
- log4j.appender.appender2.layout=org.apache.log4j.PatternLayout
- log4j.appender.appender2.layout.ConversionPattern=[%d{HH:mm:ss:SSS}][%C-%M] -%m%n
#省略根,只设置特定包的级别和目的地 log4j.logger.com.coderdream.log4j=debug,appender1 log4j.logger.com.coderdream.log4jDao=info,appender1,appender2 #输出到控制台 log4j.appender.appender1=org.apache.log4j.ConsoleAppender #设置输出样式 log4j.appender.appender1.layout=org.apache.log4j.PatternLayout #自定义样式 # %r 时间 0 # %t 方法名 main # %p 优先级 DEBUG/INFO/ERROR # %c 所属类的全名(包括包名) # %l 发生的位置,在某个类的某行 # %m 输出代码中指定的讯息,如log(message)中的message # %n 输出一个换行符号 log4j.appender.appender1.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%C-%M] %m%n #输出到文件(这里默认为追加方式) log4j.appender.appender2=org.apache.log4j.FileAppender #设置文件输出路径 #【1】文本文件 log4j.appender.appender2.File=c:/Log4JDemo07_Dao.log #设置文件输出样式 log4j.appender.appender2.layout=org.apache.log4j.PatternLayout log4j.appender.appender2.layout.ConversionPattern=[%d{HH:mm:ss:SSS}][%C-%M] -%m%n
【示例8】 log4j.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="appender1"
- class="org.apache.log4j.RollingFileAppender">
- <param name="File" value="logfile08.html" />
- <param name="MaxFileSize" value="1MB" />
- <param name="MaxBackupIndex" value="5" />
- <layout class="org.apache.log4j.HTMLLayout">
- </layout>
- </appender>
- <root>
- <level value="debug" />
- <appender-ref ref="appender1" />
- </root>
- </log4j:configuration>
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> <appender name="appender1" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="logfile08.html" /> <param name="MaxFileSize" value="1MB" /> <param name="MaxBackupIndex" value="5" /> <layout class="org.apache.log4j.HTMLLayout"> </layout> </appender> <root> <level value="debug" /> <appender-ref ref="appender1" /> </root> </log4j:configuration>
为了提高效率,我们可以在写日志前增加判断:
- // 记录debug级别的信息
- if (logger.isDebugEnabled()) {
- logger.debug("This is debug message from Dao.");
- }
- // 记录info级别的信息
- if (logger.isInfoEnabled()) {
- logger.info("This is info message from Dao.");
- }
- // 记录error级别的信息
- logger.error("This is error message from Dao.");