<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Java蜘蛛人 歡迎大家

    歡迎大家 來到我的blog , 如果我身邊的朋友 有什么不懂可以直接來問我 我會細心的幫助你的. 如果網絡上的朋友有什么不懂的 可以加我Java蜘蛛人 QQ48187537
    posts - 54, comments - 192, trackbacks - 0, articles - 1

    Spring 配置log4j

    Posted on 2009-02-12 15:16 Java蜘蛛人 --鄭成橋 閱讀(21003) 評論(0)  編輯  收藏

      Log4j是Apache的一個開放源代碼項目,通過使用Log4j,我們可以控制日志信息輸送的目的地是控制臺、文件、GUI組件、甚至是套接口服務器、NT的事件記錄器、UNIX Syslog守護進程等;我們也可以控制每一條日志的輸出格式;通過定義每一條日志信息的級別,我們能夠更加細致地控制日志的生成過程。最令人感興趣的就是,這些可以通過一個配置文件來靈活地進行配置,而不需要修改應用的代碼。

         如此強大的優越性,實際上手并不難,尤其在spring框架下,使用log4j更是容易,下面介紹一下spring下的log4j應用。
        當然先要下載相應的jar包(log4j.jar)
    首先是web.xml的配置,在web.xml中加入如下配置
       <context-param>
          <param-name>log4jConfigLocation</param-name>
          <param-value>/WEB-INF/props/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>

    說明:在上文的配置里,在上文的配置里,Log4jConfigListener會去WEB-INF/props/log4j.propeties 讀取配置文件;開一條watchdog線程每60秒掃描一下配置文件的變化(這樣在web服務啟動后再去修改配置文件也不用重新啟動web服務了);并把web目錄的路徑壓入一個叫webapp.root的系統變量(webapp.root將在log4j.properties文件中使用)。

    接下來是log4j.properties配置文件了,把它放在WEB-INF/props下,具體配置如下:

    #log4j.rootLogger = [ level ] , appenderName, appenderName, ...
    log4j.rootLogger = INFO, console, R
    #level=INFO,all can be output
    #console is set to be a ConsoleAppender
    log4j.appender.console = org.apache.log4j.ConsoleAppender
    #console have four patterns
    #org.apache.log4j.HTMLLayout
    #org.apache.log4j.PatternLayout
    #org.apache.log4j.SimpleLayout
    #org.apache.log4j.TTCCLayout

    log4j.appender.console.layout = org.apache.log4j.PatternLayout
    #define the output type
    log4j.appender.console.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
    #file is set to output to a extra file
    log4j.appender.R = org.apache.log4j.RollingFileAppender
    #the absolute route of the log4j file
    log4j.appender.R.File = /log.txt
    #the size
    log4j.appender.R.MaxFileSize = 500KB
    #back up a file
    log4j.appender.R.MaxBackupIndex = 1
    log4j.appender.R.layout = org.apache.log4j.PatternLayout
    log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] - %m%n

    上面的配置文件說明log信息將以兩種方式輸出(文件和控制臺),表示應用的根目錄下(例如本應用名稱為ABC,則log.txt的位置為tomact\webapp\ABC下)

    最后在程序中想要輸出log的地方加入log4j的支持

    (1)引入   import org.apache.log4j.Logger

    (2)聲明一個logger

    private static Logger logger = Logger.getLogger(ClassName.class);

    (3)在程序中的相應位置加入輸出信息

    logger.info("用戶登錄:"+user.getAccount());

    ok,完成了,當有登錄時會在控制臺和文件中同時輸出log信息如下

    2007-01-10 16:02:54 [com.my.web.UserAction]-[INFO] 用戶登錄:yangsq

    附注(轉):
    以下是配置文件(log4j.properties)的一些重要的語法
    定義配置文件

    其實您也可以完全不使用配置文件,而是在代碼中配置Log4j環境。但是,使用配置文件將使您的應用程序更加靈活。

    Log4j支持兩種配置文件格式,一種是XML格式的文件,一種是Java特性文件(鍵=值)。下面我們介紹使用Java特性文件做為配置文件的方法:

    配置根Logger,其語法為:

    log4j.rootLogger = [ level ] , appenderName, appenderName, …
    其中,level 是日志記錄的優先級,分為OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定義的級別。Log4j建議只使用四個級別,優先級從高到低分別是ERROR、WARN、INFO、DEBUG。通過在這里定義的級別,您可以控制到應用程序中相應級別的日志信息的開關。比如在這里定義了INFO級別,則應用程序中所有DEBUG級別的日志信息將不被打印出來。
    appenderName就是指定日志信息輸出到哪個地方。您可以同時指定多個輸出目的地。

    配置日志信息輸出目的地Appender,其語法為

    log4j.appender.appenderName = fully.qualified.name.of.appender.class
    log4j.appender.appenderName.option1 = value1

    log4j.appender.appenderName.option = valueN
    其中,Log4j提供的appender有以下幾種:
    org.apache.log4j.ConsoleAppender(控制臺),
    org.apache.log4j.FileAppender(文件),
    org.apache.log4j.DailyRollingFileAppender(每天產生一個日志文件),org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件),
    org.apache.log4j.WriterAppender(將日志信息以流格式發送到任意指定的地方)

    配置日志信息的格式(布局),其語法為:

    log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
    log4j.appender.appenderName.layout.option1 = value1

    log4j.appender.appenderName.layout.option = valueN
    其中,Log4j提供的layout有以下幾種:
    org.apache.log4j.HTMLLayout(以HTML表格形式布局),
    org.apache.log4j.PatternLayout(可以靈活地指定布局模式),
    org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串),
    org.apache.log4j.TTCCLayout(包含日志產生的時間、線程、類別等等信息)


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


    網站導航:
     
    主站蜘蛛池模板: 韩国欧洲一级毛片免费| 国产福利电影一区二区三区,亚洲国模精品一区 | 亚洲精品无码乱码成人| 久久亚洲精品无码AV红樱桃| 好久久免费视频高清| 成人免费无码视频在线网站| 亚洲国产成人无码av在线播放| 最近新韩国日本免费观看 | 久久精品夜色噜噜亚洲A∨| 久久精品亚洲综合专区| 久章草在线精品视频免费观看| 亚洲日本乱码在线观看| 国产情侣久久久久aⅴ免费| 亚洲精品免费观看| ww4545四虎永久免费地址| 亚洲制服丝袜精品久久| 在线观看免费毛片| 狠狠热精品免费观看| 久久久久亚洲爆乳少妇无| 一个人看的www免费视频在线观看| 亚洲AV无码乱码在线观看裸奔| 一级特黄aa毛片免费观看| 亚洲伦理中文字幕| 全亚洲最新黄色特级网站 | 青青青亚洲精品国产| 国产亚洲AV手机在线观看| 久久久久国产精品免费网站| 亚洲网站视频在线观看| 亚洲AV日韩综合一区尤物| 四虎影视在线永久免费看黄| 人成午夜免费大片在线观看| 亚洲国产精品久久久久婷婷老年 | 久久久久亚洲精品成人网小说| 亚洲电影免费观看| 自拍偷自拍亚洲精品播放| 国产V亚洲V天堂无码久久久| 国产精品视频永久免费播放| 成人免费777777被爆出| 亚洲午夜一区二区三区| 区三区激情福利综合中文字幕在线一区亚洲视频1 | 最新国产乱人伦偷精品免费网站|