WEB系统启动时加载Log4j的配置文件

原创 2013年12月04日 10:01:54

在整个WEB系统中,为了统一的使用日志管理,需要在系统启动的时候就加载Log4j的配置文件,这样才能保证以后使用log4j的格式是一致的,便于跟踪和解决问题。

那么,如何在系统启动的时候加载log4j的配置文件呢?下面我简单的介绍一下:

 

1、在web.xml文件中添加一个“监听器”

<!-- 加载log4j的配置信息 -->
  <listener>
  	<listener-class>hb.init.log4j.Log4jInit</listener-class>
  </listener>

 

2、“监听类”继承“ServletContextListener”接口

package hb.init.log4j;

import java.io.FileInputStream;
import java.io.IOException;
import java.util.Properties;
import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;

public class Log4jInit implements ServletContextListener{
	
	Logger log = Logger.getLogger(Log4jInit.class);
	
	public void contextDestroyed(ServletContextEvent sce) {
		log.info("Log4jInit contextDestroyed!");
	}

	public void contextInitialized(ServletContextEvent sce) {
		
		//得到servletContext对象的方法
		ServletContext sc = sce.getServletContext();
		//指明文件的相对路径就能够得到文件的绝对路径
		System.out.println(sc.getRealPath("/"));
		String path = sc.getRealPath("/config/log4j.properties");
		
		//启动服务器的时候加载日志的配置文件
		init(path,sc);
		log.info("log4j");
	}
	
	
	/**
	 * 
	 * @param path 配置文件的路径
	 * @param sc ServletContext对象
	 */
	public void init(String path,ServletContext sc){
		FileInputStream istream = null;
		try{
			Properties props = new Properties();
			//加载配置文件
			istream = new FileInputStream(path);
			props.remove("log4j.appender.file.File");
			System.out.println(sc.getRealPath("/log/hb.log"));
			//指明log文件的位置
			props.put("log4j.appender.file.File", sc.getRealPath("/log/hb.log"));
			//加载文件流,加载Log4j文件的配置文件信息
			props.load(istream);
			PropertyConfigurator.configure(props);
		} catch (Exception ex){
			try {
				throw new Exception(ex);
			} catch (Exception e) {
				e.printStackTrace();
			}
		} finally{
			try {
				istream.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
	}
	
	
}

 

加载log4j的配置文件的目的是为了使日志文件“放在跟工程相对路径的地方”,这样即使将项目移植到不同的操作系统上面,显示也是正常的

 

 

 

 

 

相关文章推荐

WEB系统启动时加载Log4j的配置文件(自己写Listener形式)

在整个WEB系统中,为了统一的使用日志管理,需要在系统启动的时候就加载Log4j的配置文件,这样才能保证以后使用log4j的格式是一致的,便于跟踪和解决问题。 那么,如何在系统启动的时候加载lo...
  • JIESA
  • JIESA
  • 2016年04月28日 15:42
  • 1141

Log4j2介绍和特性实例(六)--配置文件不在默认路径下的加载

Log4j2配置文件路径设置

log4j的使用与java中properties配置文件加载

日志是我们在写代码中经常会用到的,程序出错了我们也需要去查看日志来调错,对于像我们这一些新人来说,怎么去使用日志就比较陌生,下面我将我学习的过程分享一下: 1.需要找到一个log4j包,我使用的是l...

log4j配置文件详解及手动加载的方式

一、配置文件说明: 1、log4j.rootLogger=INFO, stdout, R    将等级为INFO的日志信息使用stdout和R进行输出,这里可以自己命名;     等级可分为OFF、F...

tomcat下多个web应用使用相同的log4j的jar包,如何避免配置文件发生冲突

我们在开发的时候通常会遇到再同一个服务器下开发多个应用的情况,在公共jar包统一加载的情况下,如果log4j.properties配置不当,经常会发生多个应用的log日志都打印到一个文件里了,如果配置...

java应用(非web应用)中log4j.properties动态修改配置文件,无需重启,就能立即生效,如何实现?

java应用(非web应用)中log4j.properties动态修改配置文件,无需重启,就能立即生效,如何实现?   主要使用:PropertyConfigurator.configureAnd...
  • tower888
  • tower888
  • 2011年05月29日 09:09
  • 11923

Web应用中Log4j与JNDI结合1 -- JNDI指定配置文件

Web应用中Log4j和JNDI结合指定Log4j配置文件和Log路径第一步:JNDI指定配置文件

Java Web - 日志-log4j(二)--配置文件说明

一、Log4j说明   1 log4j.rootCategory=INFO, stdout , R   此句为将等级为INFO的日志信息输出到stdout和R这两个目的地,stdout和R的定义在...
  • luckycz
  • luckycz
  • 2015年09月24日 16:49
  • 448

Log4j配置文件解析以及加载自己的配置文件

Log4j配置文件解析以及加载自己的配置文件 log4jjava  一、配置文件说明: 1、log4j.rootLogger=INFO, stdout, R    将等级为INFO的日志信息使...

java解析XML配置文件及log4j开源日志系统

java解析XML配置文件及log4j开源日志系统java解析XML配置文件参考文章:http://blog.csdn.net/magister_feng/article/details/745436...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:WEB系统启动时加载Log4j的配置文件
举报原因:
原因补充:

(最多只允许输入30个字)