1、工程中引入log4j-1.2.14.jar
2、工程中增加一个servlet,源程序如下:
package com.xgsj.servlets;
import java.io.IOException;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.log4j.PropertyConfigurator;
/**
类介绍:初始化log4j
开发人员:xjxhd
创建日期:
修改日期:
*/
public class InitLog4j extends HttpServlet {
private static final String CONTENT_TYPE = "text/html; charset=GBK";
public static String CONTEXT_PATH="";
/**
* Constructor of the object.
*/
public InitLog4j() {
super();
}
/**
* Destruction of the servlet. <br>
*/
public void destroy() {
super.destroy(); // Just puts "destroy" string in log
// Put your code here
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
}
public void init() throws ServletException {
// Put your code here
ServletContext sct=getServletContext();
String prefix = sct.getRealPath("/");
CONTEXT_PATH=prefix;
//log4j 配置文件存放目录
System.out.println("[....Log4j]: The Root Path: " + prefix);
System.out.println("[....Log4j]: InitServlet init start...");
String file = getInitParameter("log4j");
//log4j 配置文件
if (file != null) {
PropertyConfigurator.configure(prefix + "/"+file);
System.out.println("[....Log4j]:Property File's full name is :"+prefix + file);
//根据配置初始化log4j
}
System.out.println("[....Log4j]: InitServlet Init Sucess...");
}
}
注意红色字体部分
3、在web.xml文件中增加对上述servlet的引用
<servlet>
<servlet-name>InitLog4j</servlet-name>
<servlet-class>com.xgsj.servlets.InitLog4j</servlet-class>
<init-param>
<param-name>log4j</param-name>
<param-value>/WEB-INF/log4j.properties</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>InitLog4j</servlet-name>
<url-pattern>/servlet/InitLog4j</url-pattern>
</servlet-mapping>
4、在项目中增加log4j.properties文件,例如上面红色字体所示,该文件放在WEB-INF下,文件内容如下:
log4j.rootLogger=debug, stdout, R
#log4j.rootLogger=error, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
#log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.stdout.layout.ConversionPattern=%5p [%d{yyyy-MM-dd HH:mm:ss}] (%F:%L) - %m%n
#R
log4j.appender.R=org.apache.log4j.RollingFileAppender
#log4j.appender.R.File=/usr/IBM/WebSphere/AppServer/profiles/AppSrv01/installedApps/loopbackNode01Cell/PoliceWeb_war.ear/PoliceWeb.war/WEB-INF/logs/police.log
#log4j.appender.R.File==${webapp}//logs//police.log
#log4j.appender.R.File==../logs/police.log
log4j.appender.R.File=D://work//myeclipse//GsjOa//WebRoot//WEB-INF//logs//oa.log
log4j.appender.R.MaxFileSize=1024KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=10
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%5p [%d{yyyy-MM-dd HH:mm:ss}] (%F:%L) - %m%n
注意上述路径用两个斜杠代表地址分割符
5、测试类如下:
import com.xgsj.util.ConnDataBase;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.HashMap;
import org.apache.log4j.Logger;
import java.sql.Connection;
import java.util.*;
public class FunctionManager {
public ArrayList queryAllModules()//查询所有模块
{
Connection conn = null;
Statement stmt = null;
ResultSet rst=null;
ArrayList ret=new ArrayList();
String sql="select * from modules order by mkbh";
Logger logger=Logger.getRootLogger();
logger.debug(sql);
ConnDataBase db=new ConnDataBase();
conn=db.getConnection();
try
{
stmt = conn.createStatement();
rst = stmt.executeQuery(sql);
while (rst.next()) {
HashMap hm=new HashMap();
hm.put("mkbh",rst.getString("mkbh"));
hm.put("mkmc",rst.getString("mkmc"));
hm.put("mkxh", rst.getString("mkxh"));
ret.add(hm);
}
}
catch(Exception e)
{
e.printStackTrace();
}
finally{
try
{
if (rst != null)
rst.close();
if (stmt!=null)
stmt.close();
if (conn!=null)
conn.close();
}
catch(Exception e)
{
e.printStackTrace();
}
}
return ret;
}
}
注意该类中的红色字体,就是应用log4j的方法,好了,就那么简单,在log4j.properties中还可以指定输出日志的格式和输出文件的位置,自己试试。