Log4j在Java WebApp的配置
来源:互联网 发布:手机注册淘宝会员名 编辑:程序博客网 时间:2024/06/06 04:05
第一步:在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(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());
- }
- Log4j在Java WebApp的配置
- log4j配置webapp日志系统
- Log4J配置错误 - 关于webapp.root的设置
- 深入浅析java web log4j 配置及在web项目中配置Log4j的技巧
- 深入浅析java web log4j 配置及在web项目中配置Log4j的技巧
- 在 Tomcat 上配置WebApp
- java-log4j的简单配置
- java之log4j的配置
- Ant 对java webapp打包war 的配置
- log4j---log4j 的配置
- Log4J 在系统运行时更改log4j的配置
- log4j在tomcat下多个工程的log4j.properties配置
- Log4J 在系统运行时更改log4j的配置
- Log4J 在系统运行时更改log4j的配置
- Web.xml Webapp配置加载log4j和Spring
- 在Spring的项目中配置Log4j
- 在spring中如何配置的log4j
- 在Spring的项目中配置Log4j
- W3C XML Schema 支持的Unicode字符类
- 消息队列不同进程之间通信
- fast ubuntu download
- 黑马程序员-java反射机制
- usaco 3.4.4
- Log4j在Java WebApp的配置
- Opencv 向量的一阶差分函数封装实现 功能等价于Matlab的diff函数 附:显示CvMat的函数封装
- 数据结构&算法实践-Python——序章
- 一个IT男的职业发展全景图
- OO真经——关于面向对象的哲学体系及科学体系的探讨
- 我是如何一年写出三本编程书籍的
- TerminateProess结束进程
- 你知道吗?
- 第十二章1