日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

log4j配置文件中的变量

發布時間:2024/8/1 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 log4j配置文件中的变量 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我們做log4j配置的時候,經常會使用到這樣的變量${log.dir}或者${log.home},這個變量的值來自系統屬性,就是通過System.setProperty("log.home","log.home")來設置的。而且System.setProperty()方法調用需要在系統啟動的過程中在聲明private static final Logger log = Logger.getLogger(App.class)之前。

如果是web項目,我們可以在web.xml文件中配置一個listener,在這個listener之中,我們設置log.home。

<listener><listener-class>com.xxx.listener.Log4jConfigListener</listener-class> </listener>

Log4jConfigListener.java

package com.xxx.listener; import javax.servlet.ServletContextEvent; import javax.servlet.ServletContextListener; public class Log4jConfigListener implements ServletContextListener {@Overridepublic void contextInitialized(ServletContextEvent sce) {System.setProperty("log.dir", "D:/log");}@Overridepublic void contextDestroyed(ServletContextEvent sce) {} }

這樣,我們在log4j.properties或者log4j.xml配置文件中指定的變量${log.dir}就會被解析了。

如果不是web項目,在啟動類中,我們可以利用static靜態代碼塊來設置log.dir系統屬性。如下所示:

package com.xxx.log4j.test; import java.util.Random; import org.apache.log4j.Logger; public class Hello {static{System.setProperty("log.dir", "D:/log");} private static final Logger log = Logger.getLogger(Hello.class);public static void main(String[] args) { String str = "this is a log4j test string @ "+new Random().nextInt();log.info(str);} }

這樣我們的變量${log.dir}就能被解析,其他的變量類似。

另外,也可以在啟動web容器或者主程序的時候,通過-Dlog.dir=D:/log來指定系統屬性。總之,系統屬性需要設置在Logger聲明之前。一般根據需要合理設置。?

總結

以上是生活随笔為你收集整理的log4j配置文件中的变量的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。