1.把log4j-1.2.8.jar放到你的lib下,設置好classpath
2.添加配置文件.
配置文件取名log4j.properties,直接放到WEB-INF/classes下即可
例如:
log4j.rootLogger=DEBUG, ROOT
log4j.appender.ROOT=org.apache.log4j.RollingFileAppender
log4j.appender.ROOT.File=MMQB_Debug_Info.log
log4j.appender.ROOT.MaxFileSize=200KB
log4j.appender.ROOT.MaxBackupIndex=5
log4j.appender.ROOT.layout=org.apache.log4j.PatternLayout
log4j.appender.ROOT.layout.ConversionPattern=[%d] %c %-5p - %m%n
#log4j.logger.com.webage.ejbs=INFO
3.在程序中
protected Log log = LogFactory.getLog(this.getClass().getName());
log.debug("debug infomation");
首先建立一个servlet
/*
* 创建日期 2005-4-4
*
* TODO 要更改此生成的文件的模板,请转至
* 窗口 - 首选项 - Java - 代码样式 - 代码模板
*/
package cn.wst.common.log4j;
/*
* 创建日期 2005-3-8
*
* 源文件: MyLog4jInit.java
*/
import java.io.IOException;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.log4j.xml.DOMConfigurator;
import org.apache.log4j.PropertyConfigurator;
/**
* 用于初始化Log4j
*
* @author wst
* @version 1.0
*/
public class MyLog4jInit extends HttpServlet {
public void init(ServletConfig config) throws ServletException {
super.init(config);
String prefix = getServletContext().getRealPath("/");
String file = getInitParameter("log4j"); // if the log4j-init-file is ot
System.out.println("-------- Log4J Start [AddressBook] --------- ");
if ( file != null ) {
DOMConfigurator.configure(prefix + file);
// PropertyConfigurator.configure(prefix+file);
}
}
protected void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
}
}
然后在web-inf里面的最开头配置servlet
<servlet>
<servlet-name>MyLog4jInit</servlet-name>
<servlet-class>cn.wst.common.log4j.MyLog4jInit</servlet-class>
<init-param>
<param-name>log4j</param-name>
<param-value>WEB-INF/log4j.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup><!--log4j的初始化-->
</servlet>
相应在web-inf下的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="cn.wst.file.log"
class="org.apache.log4j.RollingFileAppender">
<param name="File" value="C:/addrLog.txt" />
<param name="Append" value="false" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%C:%M()]-[%p] %m%n" />
</layout>
</appender>
<appender name="cn.wst.console.log"
class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%5p (%F:%L) - %m%n" />
</layout>
</appender>
<!-- use this to turn on debug to a rolling file. -->
<root>
<level value="info" />
<appender-ref ref="cn.wst.console.log" />
<appender-ref ref="cn.wst.file.log " />
</root>
</log4j:configuration>
在程序中使用使用:假设类名为Find_hotel_servlet,则
先证明全局变量static Logger logger = Logger.getLogger(Find_hotel_servlet.class.getName());
然后使用只要Find_hotel_servlet.logger.info(*****)就可以了
posted on 2005-08-24 13:15
my java 阅读(291)
评论(0) 编辑 收藏 所属分类:
java 转帖