`
86asm
  • 浏览: 199791 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

SSH集成log4j日志环境

阅读更多

第一步:在web.xml初始化log4j

	<context-param>
		<param-name>log4jConfigLocation</param-name>
		<param-value>/WEB-INF/classes/log4j.properties</param-value>
	</context-param>

	<context-param>
		<param-name>log4jRefreshInterval</param-name>
		<param-value>6000</param-value>
	</context-param>
	<listener>
		<listener-class>
			org.springframework.web.util.Log4jConfigListener
		</listener-class>
	</listener>

 

 第二步:在上面的配置中,使用了log4j.properties作为log4j的配置文件,log4j.properties摘要代码如下:

log4j.rootLogger=ERROR,consol
log4j.logger.jmccLogger=ERROR,html

log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.SimpleLayout

log4j.appender.html=org.apache.log4j.RollingFileAppender
log4j.appender.html.maxFileSize=1KB
log4j.appender.html.maxBackupIndex=2
log4j.appender.html.file=${webapp.root}/WEB-INF/log/ex.html

log4j.appender.html.layout=org.apache.log4j.HTMLLayout
log4j.appender.html.layout.locationInfo=true

      说明:在web环境中集成log4j,关键的一步是如何找到项目真实路径,当然你也可以固执地把日志文件放在某个绝对路径上:比如log4j.appender.html.file=D:/ex.html 。但是真的要使用绝对路径吗?幸运的是spring为我们解决了此问题,spring提供了org.springframework.web.util.Log4jConfigListener监听器来初始化一些必要的log4j信息,比如它使用了System.setProperty(keyroot);  没错key=webapp.root,而root就是当前项目的真实路径(得到项目的真实路径也很简单ServletContext.getRealPath("/")),这样我们就可以使用${webapp.root}来获取项目的真实路径。

 

第三步:获取Logger对象,并在需要记录日志的地方进行日志记录。

 

补充:如果熟悉listener,并且知ServletContext.getRealPath("/"),其实这个用的频率也较高。那么完全可以写一个类似spring的Log4jConfigListener,当然也可以直接拷贝这个类,如果在项目中你并不想使用spring,只是想用log4j

 

补充2:log4j记录异常栈: Log4jUtil.getLogger()得到的是一个Logger对象

   StackTraceElement [] messages=exception.getStackTrace();
	   int length=messages.length;
	   for(int i=0;i<length;i++){
	     Log4jUtil.getLogger().error("类名:"+messages[i].getClassName());
	     Log4jUtil.getLogger().error("文件名:"+messages[i].getFileName());
	     Log4jUtil.getLogger().error("方法名:"+messages[i].getMethodName());
	     Log4jUtil.getLogger().error("行号:"+messages[i].getLineNumber());
    	}

 

4
1
分享到:
评论
1 楼 yahier 2014-10-31  
想问,不在代码中去try catch的话 log4j怎么记录项目中所有的异常信息呢

相关推荐

Global site tag (gtag.js) - Google Analytics