`

log4j.xml配置方法详解

阅读更多
log4j 有两种配置方法,大家熟知的是properties文件但是最近的项目实施中,每次去用户那里装系统,都要苦恼于log文件放在不同位置,要改property文件就要重打jar包,麻烦的紧。而如果采用 xml配置的方法,直接放在WEB-INFO下,要修改路径,很方便。查了些资料,终于把系统的log4j改成在xml中配置啦。
记一下记一下……嘿嘿
附:log4j的API http://logging.apache.org/log4j/docs/api/index.html
log4i.xml 文件

<?xml version="1.0" encoding="GB2312" ?>  
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">  
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">  
<appender name="FILE"  
  class="org.apache.log4j.RollingFileAppender">  
  <!-- 设置通道file和输出方式:org.apache.log4j.RollingFileAppender -->  
  <param name="File" value="D:/zhaotj/all.output.log" /><!-- 设置File参数:日志输出文件名 -->  
  <param name="Append" value="true" /><!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->  
  <param name="MaxBackupIndex" value="10" />  
  <layout class="org.apache.log4j.PatternLayout">  
   <param name="ConversionPattern" value="%p (%c:%L)- %m%n" /><!-- 设置输出文件项目和格式 -->  
  </layout>  
</appender>  
  
<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">  
                <!-- 设置监视器输出方式 -->  
  <layout class="org.apache.log4j.PatternLayout">  
   <param name="ConversionPattern"  
    value="%-4r [%t] %-5p %c %x - %m%n" />  
  </layout>  
                <!--滤镜设置输出的级别-->  
  <filter class="org.apache.log4j.varia.LevelRangeFilter">  
   <param name="levelMin" value="info" />  
   <param name="levelMax" value="info" />  
   <param name="AcceptOnMatch" value="true" />  
  </filter>  
</appender>  
  
<root><!-- 设置接收所有输出的通道 -->  
  <priority value="info" />  
  <appender-ref ref="FILE" /><!-- 与前面的通道id相对应 -->  
  <appender-ref ref="STDOUT" />  
</root>  
  
</log4j:configuration>  
  

建好xml文件后 要写一个servlet类继承actionservlet,当工程初始化时自动加载xml配置文件

package com.asiainfo;   
import javax.servlet.ServletException;   
import org.apache.commons.logging.Log;   
import org.apache.commons.logging.LogFactory;   
import org.apache.log4j.xml.DOMConfigurator;   
import org.apache.struts.action.ActionServlet;   
  
public class ExtendedActionServlet extends ActionServlet {   
        private Log log = LogFactory.getLog(this.getClass().getName());   
  
        public ExtendedActionServlet() {}   
  
        public void init() throws ServletException {   
            log.info(   
                    "Initializing, My MyActionServlet init this System's Const Variable");   
            String prefix = this.getServletConfig().getServletContext().getRealPath(   
                    "/");//读取项目的路径   
            String file = this.getServletConfig().getInitParameter("log4j");   
                       //读取log4j相对路径   
            String filePath = prefix + file;    
            DOMConfigurator.configure(filePath);//加载.xml文件          
            log.info("Initializing, end My Init");   
            super.init();//应用了struts,此方法不能省,ActionServlet覆盖了的此方法中有很多重要操作   
        }   
}   
  

我们可以看到 在此类中 用了相对路径来加载xml的方法,首先通过prefix 读取了项目的路径 然后再通过读取web.xml中的log4j变量,获得log4j.xml的相对路径 两者结合 就是他的绝对路径拉
最后在web.xml中配置action信息 就可以实现加载啦
web.xml

    <servlet>  
<servlet-name>action</servlet-name>  
<servlet-class>  
  com.asiainfo.ExtendedActionServlet   
</servlet-class>  
<init-param>  
  <param-name>config</param-name>  
  <param-value>/WEB-INF/struts-config.xml</param-value>  
</init-param>  
  
<!-- tsExtend  -->  
<init-param>  
  <param-name>config/tsextend</param-name><!--设备检测子模块-->  
  <param-value>  
   /WEB-INF/tsextend/struts-config.xml   
  </param-value>  
</init-param>  
               <init-param>  
  <param-name>log4j</param-name><!--log4j.xml的路径-->  
  <param-value>  
   /WEB-INF/log4j.xml   
  </param-value>  
</init-param>  
<init-param>  
  <param-name>info</param-name>  
  <param-value>3</param-value>  
</init-param>  
<init-param>  
  <param-name>detail</param-name>  
  <param-value>3</param-value>  
</init-param>  
<load-on-startup>0</load-on-startup><!--设置当工程初始时便执行-->  
</servlet>  
  
<servlet-mapping>  
<servlet-name>action</servlet-name>  
<url-pattern>*.do</url-pattern>  
</servlet-mapping>
分享到:
评论

相关推荐

    log4j.jar及log4j.xml

    要在项目中使用Log4j,首先需要将`log4j.jar`添加到项目的类路径中,然后创建或引用`log4j.xml`配置文件。在代码中,通过以下方式创建和使用Logger: ```java import org.apache.log4j.Logger; public class ...

    log4j.properties配置详解 使用教程

    log4j的核心配置文件通常是`log4j.properties`或`log4j.xml`,这里重点介绍`.properties`文件的配置方法。 ##### 3.1 配置文件基础结构 ```properties # 设置root logger的级别和输出目标 log4j.rootLogger=LEVEL,...

    SSM整合中的Log4j日志的配置详情

    Log4j 在 SSM 整合中的配置详解 Log4j 是一个功能强大且广泛使用的日志记录工具,特别是在 SSM(Spring、Spring MVC、Mybatis)整合项目中,合理地配置 Log4j 对项目的日志记录和输出至关重要。本文将详细介绍 SSM...

    log4j.xml文件的配置文.pdf

    #### 三、`log4j.xml`配置详解 下面我们将基于提供的部分`log4j.xml`文件内容,详细解释各个元素的作用及配置方法。 ##### 1. XML声明 ```xml &lt;?xml version="1.0" encoding="UTF-8"?&gt; ``` 这部分指定了XML文档的...

    Log4j.properties配置详解

    ### Log4j.properties配置详解 #### 一、Log4j简介 Log4j是一个非常流行的Java日志框架,它能够帮助开发者轻松管理日志记录。Log4j的主要优点包括灵活性高、性能好以及易于配置。它由三个核心组件组成:记录器...

    log4j配置文件说明(完整版)

    Log4j 配置文件说明 Log4j 是一种流行的日志记录工具,用于记录和管理应用程序中的日志信息。配置文件是 Log4j 的核心组件之...了解 Log4j 配置文件的基本结构和配置方法,可以更好地使用 Log4j 实现日志记录和管理。

    log4j2-所需jar包+配置详解(详细)

     log4j 2.x版本不再支持像1.x中的.properties后缀的文件配置方式,2.x版本配置文件后缀名只能为".xml",".json"或者".jsn".  系统选择配置文件的优先级(从先到后)如下:  (1).classpath下的名为log4j2-test.json...

    log4j.properties配置详解.doc

    在实际应用中,通过修改`log4j.properties`或`log4j.xml`文件,可以轻松调整日志配置,满足不同环境和需求。例如,开发阶段可能需要DEBUG级别的详细日志,而生产环境中可能只需要ERROR级别的日志,这时只需更改配置...

    Log4.properties配置详解

    ### Log4j配置详解 #### 一、Log4j简介 Log4j 是一款非常流行的 Java 日志框架,由 Apache 软件基金会所提供。它能够帮助开发者在应用程序中记录日志信息,使得应用程序能够在运行时更加透明地展示其内部状态。Log...

    log4j中配置日志文件相对路径方法(PDF)

    ### Log4j中配置日志文件相对路径方法详解 #### 概述 在软件开发过程中,日志记录是一项重要的功能,它有助于开发者调试程序、监控应用程序的运行状态以及追踪问题。`Log4j`作为一款优秀的日志管理工具,被广泛应用...

    applicationContext.xml 详细配置

    ApplicationContext.xml 配置详解 ApplicationContext.xml 是 Spring 框架中用于配置应用程序的核心配置文件。通过该文件,可以定义 Bean、数据源、Session 工厂、 Hibernate 配置等相关信息,从而实现应用程序的...

    log4j.properties详解与例子

    Log4j支持两种配置格式:XML和Properties(键值对)。本篇主要关注Properties格式。 1. 配置根Logger: 根Logger是所有其他Logger的默认父Logger,它定义了日志记录的全局行为。`log4j.rootLogger`的语法如下: `...

    SpringBoot框架配置log4j和log4j2的配置代码

    2. **配置文件**:创建`log4j.properties`或`log4j.xml`文件,定义日志级别和输出目的地。例如: ```properties # log4j.properties 示例 log4j.rootLogger=DEBUG, stdout, file log4j.appender.stdout=org.apache....

    log4j和ibatis配置文档

    《log4j与iBatis配置详解》 在软件开发中,日志管理和数据库操作是两个至关重要的环节。Log4j作为Java世界里最流行的日志框架之一,它提供了强大的日志记录功能,帮助开发者追踪应用程序运行过程中的信息、警告、...

    log4j常用配置详解

    ### log4j常用配置详解 ### #### 一、log4j.properties 配置解析 #### 在Java开发领域中,log4j是一款非常流行的日志框架,它提供了丰富的配置选项来满足不同场景下的日志记录需求。本文将详细介绍两种常见的log4j...

    log4j.1.2.7

    Log4j的核心配置文件是`log4j.properties`或`log4j.xml`。在1.2.7版本中,你可以通过配置文件指定日志的输出级别、输出目标和格式。例如: ```properties # log4j.properties 示例 log4j.rootLogger=INFO, stdout, ...

    log4j详解配置说明

    ### Log4j 配置详解 #### 一、概述 Log4j 是一款非常流行的 Java 日志框架,它提供了一种灵活的日志记录机制。在实际应用中,开发者可以通过简单的配置来实现对日志级别的控制、日志信息的格式化以及日志文件的...

    log4j配置和加载方法

    ### Log4j配置与加载方法详解 Log4j是一款由Apache出品的日志记录工具,它提供了灵活的日志级别控制和多样化的日志输出方式,广泛应用于Java应用的开发中。本文将深入解析log4j的配置与加载机制,帮助开发者更好地...

    新版本与旧版本log4j.jar包下载,附使用说明----.zip

    3. **IDEA与log4j**: IntelliJ IDEA(简称IDEA)是一款流行的Java集成开发环境,它支持将log4j集成到项目中,通过配置pom.xml或build.gradle文件添加依赖,或者手动将log4j.jar添加到项目的类路径下,以便在IDEA中...

Global site tag (gtag.js) - Google Analytics