随笔 - 163  文章 - 2  评论 - 370  阅读 - 46万 

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

Xml代码  收藏代码
  1. <context-param>  
  2.     <param-name>log4jConfigLocation</param-name>  
  3.     <param-value>/WEB-INF/classes/log4j.properties</param-value>  
  4. </context-param>  
  5.   
  6. <context-param>  
  7.     <param-name>log4jRefreshInterval</param-name>  
  8.     <param-value>6000</param-value>  
  9. </context-param>  
  10. <listener>  
  11.     <listener-class>  
  12.         org.springframework.web.util.Log4jConfigListener  
  13.     </listener-class>  
  14. </listener>  

 

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

Xml代码  收藏代码
  1. log4j.rootLogger=ERROR,consol  
  2. log4j.logger.jmccLogger=ERROR,html  
  3.   
  4. log4j.appender.console=org.apache.log4j.ConsoleAppender  
  5. log4j.appender.console.layout=org.apache.log4j.SimpleLayout  
  6.   
  7. log4j.appender.html=org.apache.log4j.RollingFileAppender  
  8. log4j.appender.html.maxFileSize=1KB  
  9. log4j.appender.html.maxBackupIndex=2  
  10. log4j.appender.html.file=${webapp.root}/WEB-INF/log/ex.html  
  11.   
  12. log4j.appender.html.layout=org.apache.log4j.HTMLLayout  
  13. 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对象

Java代码  收藏代码
  1. StackTraceElement [] messages=exception.getStackTrace();  
  2.  int length=messages.length;  
  3.  for(int i=0;i<length;i++){  
  4.    Log4jUtil.getLogger().error("类名:"+messages[i].getClassName());  
  5.    Log4jUtil.getLogger().error("文件名:"+messages[i].getFileName());  
  6.    Log4jUtil.getLogger().error("方法名:"+messages[i].getMethodName());  
  7.    Log4jUtil.getLogger().error("行号:"+messages[i].getLineNumber());  
  8.     }  

 

posted on   风浪  阅读(2807)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示