SSH集成log4j日志环境
来源:互联网 发布:java实现报表 编辑:程序博客网 时间:2024/06/05 14:59
第一步:在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,consollog4j.logger.jmccLogger=ERROR,htmllog4j.appender.console=org.apache.log4j.ConsoleAppenderlog4j.appender.console.layout=org.apache.log4j.SimpleLayoutlog4j.appender.html=org.apache.log4j.RollingFileAppenderlog4j.appender.html.maxFileSize=1KBlog4j.appender.html.maxBackupIndex=2log4j.appender.html.file=${webapp.root}/WEB-INF/log/ex.htmllog4j.appender.html.layout=org.apache.log4j.HTMLLayoutlog4j.appender.html.layout.locationInfo=true
说明:在web环境中集成log4j,关键的一步是如何找到项目真实路径,当然你也可以固执地把日志文件放在某个绝对路径上:比如log4j.appender.html.file=D:/ex.html 。但是真的要使用绝对路径吗?幸运的是spring为我们解决了此问题,spring提供了org.springframework.web.util.Log4jConfigListener监听器来初始化一些必要的log4j信息,比如它使用了System.setProperty(key, root); 没错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());
- }
- SSH集成log4j日志环境
- SSH集成log4j日志环境
- 搭建 log4j 日志环境
- Log4j 日志环境搭建
- Spring集成log4j日志管理
- Spring集成log4j日志管理
- Spring集成log4j日志管理
- SSH的log4j日志记录
- Hibernate4配置log4j日志环境
- hibernate搭建Log4j日志环境
- eclipse搭建Log4J日志环境
- hibernate 搭建log4j日志环境
- Hibernate----搭建log4j日志环境
- Hibernate4配置log4j日志环境
- log4j集成Rsyslog系统日志详解
- Spring 中集成log4j日志框架
- SSH项目环境配置之log4j.properties
- SSH环境配置之log4j.properties
- 致敬--著名计算机黑客Aaron Swartz
- matlab中脚本文件和函数文件
- dav视频播放器
- 让CPU占用率曲线听你指挥
- 分享7个超实用的Emmet(zen coding)HTML代码使用技巧
- SSH集成log4j日志环境
- java1.5 与 1.4 相比 --新特性
- Myeclipse如何最佳设置
- Java 1.5和1.6中新特性
- Android eclipse中程序调试
- hibernate刷新数据时的缓存问题
- HashSet HashMap Hashtable
- LinkList、ArrayList、Vector区别;及 Set
- 健康的使用鼠标