gpt4 book ai didi

java - 如何让 JSF 登录到 log4j

转载 作者:行者123 更新时间:2023-12-01 05:29:26 25 4
gpt4 key购买 nike

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

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

我在网上找到了一些建议,建议我将 log4j JAR 放入具有适当 log4j.properties 的类路径中,并排除公共(public)日志记录 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>

我的原型(prototype)代码也在 github 上:https://github.com/pjgrenyer/EmbeddedTomcat

最佳答案

您可能需要考虑为日志外观配置应用程序,该外观允许您通过单一来源重定向来自 Log4j 和 Apache Commons Logging 的所有应用程序日志记录。如果第三方 jar 决定使用 Apache Commons,那么除了逆向工程或自定义可用的 FOSS 代码之外,没有什么办法可以让它直接使用 Log4j。

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

查看 SLF4J,最新版本的 Hibernate 需要此依赖项,因此如果您使用 Hibernate,您的类路径中可能已经有此依赖项。

http://www.slf4j.org/

关于java - 如何让 JSF 登录到 log4j,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9224806/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com