log4j的使用步骤

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了log4j的使用步骤相关的知识,希望对你有一定的参考价值。

WEB项目中如何使用?请把具体步骤写上,日志打印到文件中。
我没有Spring框架,我的是配置文件log4j.xml出问题了:
log4j:WARN No appenders could be found for logger (org.apache.struts.util.PropertyMessageResources).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN Continuable parsing error 18 and column 23

  一、使用步骤:
  第一步
  加入log4j-1.2.8.jar(可以选择log4j的更高版本)到lib下。
  第二步
  在CLASSPATH下建立log4j.properties。内容如下(数字为行号):
  1 log4j.rootCategory=INFO, stdout , R
  2
  3 log4j.appender.stdout=org.apache.log4j.ConsoleAppender
  4 log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
  5 log4j.appender.stdout.layout.ConversionPattern=[QC] %p [%t] %C.%M(%L) | %m%n
  6
  7 log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
  8 log4j.appender.R.File=D:\\\\Tomcat 5.5\\\\logs\\\\qc.log
  9 log4j.appender.R.layout=org.apache.log4j.PatternLayout
  10 log4j.appender.R.layout.ConversionPattern=%d-[TS] %p %t %c - %m%n
  11
  12 log4j.logger.com.neusoft=DEBUG
  13 log4j.logger.com.opensymphony.oscache=ERROR
  14 log4j.logger.net.sf.navigator=ERROR
  15 log4j.logger.org.apache.commons=ERROR
  16 log4j.logger.org.apache.struts=WARN
  17 log4j.logger.org.displaytag=ERROR
  18 log4j.logger.org.springframework=DEBUG
  19 log4j.logger.com.ibatis.db=WARN
  20 log4j.logger.org.apache.velocity=FATAL
  21
  22 log4j.logger.com.canoo.webtest=WARN
  23
  24 log4j.logger.org.hibernate.ps.PreparedStatementCache=WARN
  25 log4j.logger.org.hibernate=DEBUG
  26 log4j.logger.org.logicalcobwebs=WARN
  第三步
  相应的修改其中属性,修改之前就必须知道这些都是干什么的,在第二部分讲解。
  第四步
  在要输出日志的类中加入相关语句:
  定义属性:static Logger logger = Logger.getLogger(LogDemo.class); //LogDemo为相关的类
  在相应的方法中:
  if (logger.isDebugEnabled())
  logger.debug(“System …..”);
  二、log4j的简单介绍:
  Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。
  三、参考资料:
  http://baike.baidu.com/link?url=6PYC2iFZ6PPRStX30CayDL4un_UUtsh9Nfm-hcbLiMBVjygQQNActSKMmv2Z84r-V7DeQj7e4nBF8CnfBwxAHq
参考技术A 1.将log4j-1.2.14.jar加入你的项目中;
2.在src/下创建log4j.properties|log4j.xml文件;
3.在web.xml中配置log4j的信息,如下:
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/classes/log4j.properties</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
4.在项目webroot下创建你想要保存日志文件的文件夹及文件,如webroot/logs/web_app.log;
具体log4j.properties文件,给你一个示例吧,如下:
log4j.rootLogger=INFO, stdout, logfile

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
#log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n
log4j.appender.stdout.layout.ConversionPattern=- %m%n

log4j.appender.logfile=org.apache.log4j.RollingFileAppender
log4j.appender.logfile.File=$webapp.root/logs/webapp.log
log4j.appender.logfile.MaxFileSize=512KB
# Keep three backup files.
log4j.appender.logfile.MaxBackupIndex=3
# Pattern to output: date priority [category] - message
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] - %m%n

log4j.logger.com.opensymphony.xwork2=ERROR

# Control logging for other open source packages
log4j.logger.org.springframework=ERROR
log4j.logger.org.quartz=ERROR
log4j.logger.net.sf.ehcache=ERROR
log4j.logger.net.sf.navigator=ERROR
log4j.logger.org.apache.commons=ERROR
log4j.logger.org.apache.struts=ERROR

# Struts OgnlUtil issues unimportant warnings
log4j.logger.com.opensymphony.xwork2.util.OgnlUtil=error
log4j.logger.com.opensymphony.xwork2.ognl.OgnlValueStack=error
具体写法可根据自己的项目进行配置。本回答被提问者采纳

以上是关于log4j的使用步骤的主要内容,如果未能解决你的问题,请参考以下文章

java中使用日志主要分为哪几个步骤

log4j.properties 详解与配置步骤

学习笔记开源日志记录工具log4j使用方法

Java 为程序创建日志系统

log4j使用及配置详解

log4j介绍和使用