1.把log4j-1.2.8.jar放到你的lib下,設置好classpath
2.添加配置文件.例如:
log4j.rootLogger=DEBUG, ROOTlog4j.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=INFO3.在程序中
protected Log log = LogFactory.getLog(this.getClass().getName());
log.debug("debug infomation");

解决方案 »

  1.   

    阿,来晚了!
    补充一点:
    配置文件取名log4j.properties,直接放到WEB-INF/classes下即可
      

  2.   

    首先建立一个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(*****)就可以了
      

  3.   

    使用步骤:
    1.下载log4j包放到lib下2.配置好log4j.properties放到WEB-INF目录下,内容如下:
    log4j.rootLogger=info, A1 , Rlog4j.appender.stdout=org.apache.log4j.ConsoleAppender
    log4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.A1=org.apache.log4j.ConsoleAppender 
    log4j.appender.A1.layout=org.apache.log4j.TTCCLayout
    #log4j.appender.A1.layout.ConversionPattern=[%p] %d{yyyy-MM-dd HH:mm:ss} [%l]:  %m%nlog4j.appender.R=org.apache.log4j.RollingFileAppender
    log4j.appender.R.File=D:/logs/test.log
    log4j.appender.R.MaxFileSize=100KB
    log4j.appender.R.MaxBackupIndex=1
    #log4j.appender.R.layout=org.apache.log4j.PatternLayout
    log4j.appender.R.layout=org.apache.log4j.TTCCLayout
    #log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
    #log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
    log4j.appender.R.layout.ConversionPattern=[%p] %d{yyyy-MM-dd HH:mm:ss} [%l]: %m%n3.在程序中可以调用了:
    <%@ page import="org.apache.log4j.Logger"%>org.apache.log4j.Logger log2 = org.apache.log4j.Logger.getLogger(this.getClass());
    log2.info("调试信息");
      

  4.   

    上面的已经很详细了。其实用 google 一搜索,这样的问题,有很多解答的。。
      

  5.   

    servlet应该放在哪个目录下面啊
      

  6.   

    servlet放在放在web-inf/classes下面,建议lz先看servlet方面的知识