隨筆 - 63  文章 - 0  trackbacks - 0
          <2009年5月>
          262728293012
          3456789
          10111213141516
          17181920212223
          24252627282930
          31123456

          常用鏈接

          留言簿(2)

          隨筆分類

          隨筆檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          Log4j下載
          在apache網(wǎng)站:jakarta.apache.org/log4j 可以免費下載到Log4j最新版本的軟件包。

          Log4j使用
          Log4j的包下載完成后,解壓,將其中打包好的的log4j-1.x.x.jar導(dǎo)入你的工程LIB中。
          Log4j之所以受歡迎的原因之一是它的靈活性。Log4j提供了靈活的配置方法,默認是調(diào)用BasicConfigurator.configure()來進行配置,但如果只是簡單的調(diào)用BasicConfigurator.configure()來進行配置工作,那么所有的配置都是固定的,不方便以后修改配置。另一種是動態(tài)配置,Log4j提供了PropertyConfigurator.configure(……)來動態(tài)配置,參數(shù)可以是一個properties文件所在路徑的String對象,可以是一個properties文件所在路徑的URL對象,也可以是一個properties對象。如果要用XML文件來配置信息,則可用類型的DOMConfigurator()函數(shù)來從一個XML文件中加載配置信息。這種方式更方便修改配置。

          動態(tài)配置

          Java代碼
          1. package http;       
          2.       
          3. import org.apache.log4j.BasicConfigurator;       
          4. import org.apache.log4j.Logger;       
          5. import org.apache.log4j.PropertyConfigurator;       
          6. import org.apache.log4j.xml.DOMConfigurator;       
          7.       
          8. public class Log4jDemo {       
          9.     static Logger log = Logger.getLogger(Log4jDemo.class.getClass());       
          10.     /**     
          11.      * main     
          12.      * @param args     
          13.      */      
          14.     public static void main(String[] args) {       
          15.         BasicConfigurator.configure();//默認配置       
          16.         PropertyConfigurator.configure("c:/log4j.properties");       
          17.         //動態(tài)配置,參數(shù)可以是一個properties文件所在路徑的String對象       
          18.         //可以是一個properties文件所在路徑的URL對象,也可以是一個properties對象       
          19.                
          20.         DOMConfigurator.configure("c:/log4j.xml");//XML配置文件       
          21.       
          22.         //PropertyConfigurator.configure()的參數(shù)還可以是XML、Properties對象       
          23.                
          24.         //下面就可使用log4j       
          25.         log.info("info");       
          26.         log.debug("debug");       
          27.         log.error("error");       
          28.         log.warn("warn");       
          29.     }       
          30.       
          31. }      


          J2EE應(yīng)用log4j
          上面代碼描述了Log4j的簡單應(yīng)用,其實使用Log4j也就是這樣簡單方便。當(dāng)然除了上面的配置方法,還有其它,比如做一個J2EE應(yīng)用,在J2EE應(yīng)用使用Log4j,必須先在啟動服務(wù)時加載Log4j的配置文件進行初始化,可以在web.xml中進行。


          java 代碼
          Java代碼
          1. import java.io.IOException;       
          2. import java.io.PrintWriter;       
          3.       
          4. import javax.servlet.ServletException;       
          5. import javax.servlet.http.HttpServlet;       
          6. import javax.servlet.http.HttpServletRequest;       
          7. import javax.servlet.http.HttpServletResponse;       
          8.       
          9.       
          10.       
          11. public class J2eeLog4jDemo extends HttpServlet {       
          12.       
          13.     public void destroy() {       
          14.         super.destroy();        
          15.     }          
          16.     public void doGet(HttpServletRequest request, HttpServletResponse response)       
          17.             throws ServletException, IOException {       
          18.     }       
          19.     public void doPost(HttpServletRequest request, HttpServletResponse response)       
          20.             throws ServletException, IOException {             
          21.     }       
          22.     public void init() throws ServletException {       
          23.         //通過web.xml來動態(tài)取得配置文件       
          24.         String prefix = getServletContext().getRealPath("/");       
          25.         String file = getInitParameter("log4j");       
          26.       
          27.         //如果沒有給出相應(yīng)的配置文件,則不進行初始化       
          28.         if(file != null)        
          29.         {       
          30.             PropertyConfigurator.configure(prefix+file);       
          31.         }       
          32.     }       
          33.       
          34. }      

          Web.xml 代碼
          Java代碼
          1. <servlet>      
          2. <servlet-name>j2eelog4jdemoservlet-name>      
          3. <servlet-class>J2eeLog4jDemoservlet-class>      
          4. <init-param>      
          5. <param-name>log4jparam-name>      
          6. <param-value>log4j.propertiesparam-value>      
          7. init-param>      
          8. <load-on-startup>1load-on-startup>  //設(shè)為1時,Web容器啟動即進行加載    
          9. servlet  


          Spring配置Log4j
          Spring中配置Log4j只要配置applicationContext.xml文件,Log4j的配置文件放在Web工程的根目錄下,默認是objectname/root下,可以在web.xml中設(shè)置工程根目錄.

          設(shè)置根目錄


          web.xml 代碼
          Java代碼
          1. <!--不定義webAppRootKey參數(shù),webAppRootKey就是缺省的"webapp.root"-->      
          2.  <context-param>      
          3.   <param-name>webAppRootKeyparam-name>      
          4.   <param-value>webapp.rootparam-value>      
          5.  context-param>  


          配置applicationContext.xml


          applicationContext.xml 代碼
          Java代碼
          1. <!--由Sprng載入的Log4j配置文件位置-->      
          2. <context-param>      
          3.  <param-name>log4jConfigLocationparam-name>      
          4.  <param-value>/WEB-INF/log4j.propertiesparam-value>      
          5.  <!--在這里定位配置文件,需要的是從root開始的絕對路徑-->      
          6. context-param>      
          7.       
          8.       
          9.       
          10. <!--Spring默認刷新Log4j配置文件的間隔,單位為millisecond-->      
          11. <context-param>      
          12.  <param-name>log4jRefreshIntervalparam-name>      
          13.  <param-value>60000param-value>      
          14. context-param>      
          15.       
          16. <!--Spring log4j 監(jiān)聽器-->      
          17. <listener>      
          18.  <listener-class>org.springframework.web.util.Log4jConfigListenerlistener-class>      
          19. listener>     


          同時使用commons-logging和Log4j


          1)首先在classpath下尋找自己的配置文件commons-logging.properties,如果找到,則使用其中定義的Log實現(xiàn)類
          2)如果找不到commons-logging.properties文件,則在查找是否已定義系統(tǒng)環(huán)境變量org.apache.commons.logging.Log,找到則使用其定義的Log實現(xiàn)類
          3)否則,查看classpath中是否有Log4j的包,如果發(fā)現(xiàn),則自動使用Log4j作為日志實現(xiàn)類
          4)否則,使用JDK自身的日志實現(xiàn)類(JDK1.4以后才有日志實現(xiàn)類)
          5)否則,使用commons-logging自己提供的一個簡單的日志實現(xiàn)類SimpleLog


          將commons-logging和Log4j的jar包都放置到classpath下,同時也將Log4j的配置文件放到classpath中,兩者就可以很好的合作,實現(xiàn)如下:
          Java代碼
          1. package com.doctorcom.model;       
          2.       
          3. import org.apache.commons.logging.Log;       
          4.       
          5. public class LogFactorySupport {           
          6.           
          7.     public Log getLog(){       
          8.         Log log = org.apache.commons.logging.LogFactory.getLog(LogFactorySupport.class);       
          9.         log.info("");       
          10.         log.debug("");       
          11.     }       
          12.            
          13. }   


          java 代碼

          Log4j配置內(nèi)容
          看一個簡單的java屬性配置文件log4j.properties:

          properties 代碼
          Java代碼
          1. #指定根Logger,及日志輸出級別,大于等于該級別的日志將被輸出( DEBUG < INFO < WARN < ERROR < FATAL ) 設(shè)為OFF可以關(guān)閉日志       
          2. log4j.rootLogger=DEBUG, A1,A2       
          3. #指定log輸出目的,這里設(shè)為輸出日志到指定目錄的文件my.log中       
          4. log4j.appender.A1=org.apache.log4j.FileAppender       
          5. log4j.appender.A1.File=\\logs\\my.log   #當(dāng)前根目錄下    
          6. #指定日志信息的格式       
          7. log4j.appender.A1.layout=org.apache.log4j.PatternLayout        
          8. log4j.appender.A1.layout.ConversionPattern=%r %d{yyyy-MM-dd HH:mm:ss} %c %p -%m%n       
          9.       
          10. #把A2輸出到控制臺       
          11. log4j.appender.A2=org.apache.log4j.ConsoleAppender       
          12. log4j.appender.A2.layout=org.apache.log4j.SimpleLayout        
          13.       
          14. #還可以單獨指定輸出某個包的日志級別       
          15. #log4j.logger.com.study.HelloLog4j=INFO   


          1、配置根Logger,其語法為:
          log4j.rootLogger = [ level ] , appenderName, appenderName2
          level:日志的級別,指定這條日志信息的重要性。分為ALL < DEBUG < INFO < WARN <error fatal=""></error>一般常用的為 DEBUG , INFO ,WARN ,ERROR四種,分別對應(yīng)Logger類的四種方法
          debug(Object message ) ;
          info(Object message ) ;
          warn(Object message ) ;
          error(Object message ) ;
          如果設(shè)置級別為INFO,則優(yōu)先級大于等于INFO級別(如:INFO、WARN、ERROR)的日志信息將可以被輸出,小于該級別的如:DEBUG將不會被輸出
          appenderName :就是指定日志信息輸出目的地,比如(打印到控制臺,輸出到文件等)。同一條日志信息可以配置多個輸出目的地。

          2、配置log輸出目的地
          Log4j提供以下幾種:
          org.apache.log4j.ConsoleAppender(控制臺)
          org.apache.log4j.FileAppender(文件)
          org.apache.log4j.DailyRollingFileAppender(每天產(chǎn)生一個日志文件)
          org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產(chǎn)生一個新的文件)
          org.apache.log4j.WriterAppender(將日志信息以流格式發(fā)送到任意指定的地方)
          3、log信息的格式
          org.apache.log4j.HTMLLayout(HTML表格形式)
          org.apache.log4j.SimpleLayout(簡單格式的日志,只包括日志信息的級別和指定的信息字符串 ,如:DEBUG - Hello)
          org.apache.log4j.TTCCLayout(日志的格式包括日志產(chǎn)生的時間、線程、類別等等信息)
          org.apache.log4j.PatternLayout(靈活地自定義日志格式)

          當(dāng)使用org.apache.log4j.PatternLayout來自定義信息格式時,可以使用
          log4j.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p -%m%n 來格式化信息
          %c    輸出所屬類的全名,可寫為 %c{Num} ,Num類名輸出的范圍  如:"com.sun.aaa.classB", %C{2}將使日志輸出輸出范圍為:aaa.classB
          %d    輸出日志時間其格式為 可指定格式 如 %d{HH:mm:ss}等
          %l    輸出日志事件發(fā)生位置,包括類目名、發(fā)生線程,在代碼中的行數(shù)
          %n    換行符
          %m    輸出代碼指定信息,如info(“message”),輸出message
          %p    輸出日志的優(yōu)先級,即 FATAL ,ERROR 等
          %r    輸出從啟動到顯示該條日志信息所耗費的時間(毫秒數(shù))
          %t    輸出產(chǎn)生該日志事件的線程名
          posted on 2009-05-04 14:37 lanxin1020 閱讀(167) 評論(0)  編輯  收藏 所屬分類: tools

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 兴城市| 青岛市| 内黄县| 涪陵区| 德阳市| 博白县| 通城县| 临泉县| 马公市| 枣强县| 宜城市| 通渭县| 南宫市| 香河县| 昌乐县| 饶河县| 上虞市| 芮城县| 德清县| 青阳县| 克山县| 隆尧县| 连州市| 开平市| 浮梁县| 古浪县| 黄冈市| 三门县| 宁河县| 平邑县| 稷山县| 潮州市| 大厂| 阳泉市| 江山市| 钦州市| 柞水县| 葫芦岛市| 固始县| 苗栗县| 云林县|