如何让JSF登录到log4j

时间:2012-02-10 08:26:51

标签: java jsf jsf-2 log4j tomcat7

我正在开发一个JSF应用程序,我想使用log4j而不是默认的记录器。

默认记录器似乎记录到标准输出。我有一些使用嵌入式tomcat运行我的应用程序的集成测试,当从Windows上的命令运行时,日志输出会导致内存不足错误。所以我想要做的是使用log4j,这是应用程序的选择记录器,并过滤大多数JSF日志。

我在Web上发现了一些建议,我需要做的就是将log4j JAR放在具有相应log4j.properties的类路径中,并排除记录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

1 个答案:

答案 0 :(得分:0)

您可能需要考虑为Logging Facade配置应用程序,该应用程序允许您将Log4j和Apache Commons Logging中的所有应用程序日志记录重定向到单个源。如果第三方jar决定使用Apache Commons,那么只需要进行逆向工程或定制可用的FOSS代码就可以直接使用Log4j。

最常见的分布式Java库将通过Logging Facade登录,而不是直接通过Log4j或类似的日志记录实现,因为它们不需要不必要的依赖,尽管恕我直言,它一直是我自己的困惑和痛苦的一点。 Apache Commons实际上是一个Logging Facade,但是它很糟糕,所以我理解你为什么要离开它。

查看SLF4J,最新版本的Hibernate需要这种依赖关系,所以如果你使用的是Hibernate,你可能已经在你的类路径上了。

http://www.slf4j.org/