2012-02-10 41 views
1

我正在開發一個JSF應用程序,我想使用log4j而不是默認的記錄器。我怎樣才能讓JSF登錄到log4j

默認記錄器似乎記錄到標準輸出。我有一些使用嵌入式tomcat運行我的應用程序的集成測試,當從命令運行時,日誌輸出會導致內存不足錯誤。所以我想要做的就是使用log4j,這是應用程序選擇的記錄器,並過濾大部分JSF日誌。

我在網上發現了一些建議我需要做的事情,把log4j JAR放在類路徑中,並加上適當的log4j.properties,並排除commons logging JAR。我試過了,它確實不是工作。

這是我的web.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
      xmlns="http://java.sun.com/xml/ns/javaee" 
      xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" 
      xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" 
      metadata-complete="true" 
      id="WebApp_ID" 
      version="3.0"> 

    <display-name>Embedded Tomcar</display-name> 
    <welcome-file-list> 
    <welcome-file>faces/index.xhtml</welcome-file> 
    </welcome-file-list> 

    <servlet> 
    <servlet-name>Faces Servlet</servlet-name> 
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class> 
    <load-on-startup>1</load-on-startup> 
    </servlet> 

    <servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>/faces/*</url-pattern> 
    </servlet-mapping> 

    <context-param> 
    <param-name>javax.servlet.jsp.jstl.fmt.localizationContext</param-name> 
    <param-value>resources.application</param-value> 
    </context-param> 

    <context-param> 
    <description>State saving method: 'client' or 'server' (=default). See JSF Specification 2.5.2</description> 
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name> 
    <param-value>client</param-value> 
    </context-param> 

    <context-param> 
    <param-name>org.apache.myfaces.ALLOW_JAVASCRIPT</param-name> 
    <param-value>true</param-value> 
    </context-param> 

    <context-param> 
    <param-name>org.apache.myfaces.PRETTY_HTML</param-name> 
    <param-value>true</param-value> 
    </context-param> 

    <context-param> 
    <param-name>org.apache.myfaces.DETECT_JAVASCRIPT</param-name> 
    <param-value>false</param-value> 
    </context-param> 

    <context-param> 
    <param-name>org.apache.myfaces.AUTO_SCROLL</param-name> 
    <param-value>true</param-value> 
    </context-param> 

    <listener> 
    <listener-class>org.apache.myfaces.webapp.StartupServletContextListener</listener-class> 
    </listener> 

</web-app> 

到我的原型代碼也GitHub上:https://github.com/pjgrenyer/EmbeddedTomcat

+0

「我已經試過了,它做的工作。」 - 拼寫錯誤? – oers 2012-02-10 08:41:32

+0

Doh!是的,謝謝你發現它。我糾正了它。 – 2012-02-10 08:55:32

回答

0

您可能需要考慮配置的日誌記錄門面,讓你重定向你的應用程序所有來自Log4j和Apache Commons的應用程序日誌記錄通過單一來源。如果第三方jar決定使用Apache Commons,那麼任何缺乏逆向工程或定製可用FOSS代碼的方法都會讓它直接使用Log4j。

最常見的分佈式Java庫將通過Logging Facade而不是直接通過Log4j或類似的日誌記錄實現登錄,因爲它們不需要不必要的依賴關係,儘管恕我直言,它一直是我自己的困惑和痛苦的一點。 Apache Commons實際上是一個記錄門面,但它很難理解,所以我明白你爲什麼要離開它。

檢查一下SLF4J,Hibernate的最新版本需要這種依賴性,所以如果你使用Hibernate,你可能已經在你的類路徑上有了這個。

http://www.slf4j.org/

+0

我的應用程序部分寫入log4j沒有任何問題。這是JSF寫入log4j我有一個問題。我發現此頁面: http://www.slf4j.org/legacy.html 併成功替換jcl-over-slf4j.jar中的commons-logging-1.1.1.jar。不過,我不能將輸出重定向到log4j,即使我已經將slf4j-log4j12-1.6.4.jar放入類路徑中。 – 2012-02-12 11:58:38