私はJSFアプリケーションを開発していますが、デフォルトのロガーではなくlog4jを使用したいと思います。JSFをlog4jにログする方法を教えてください
デフォルトのロガーは標準出力に記録されているようです。私はアプリケーションを実行するために埋め込みのTomcatを使用するいくつかの統合テストを行っており、ログ出力はWindows上のコマンドlieから実行するとメモリ不足エラーを引き起こします。だから、私がやってみたいのは、log4jを使用することです。それはとにかにアプリケーションのために選ばれたロガーです。そして、ほとんどのJSFログをフィルタリングします。
私は、必要なことをすべて提示するビットをいくつか見つけました。適切なlog4j.propertiesを持つlog4j JARをクラスパスに置き、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
「私はそれを試しても機能します。」 - スペルの間違い? – oers
Doh!はい、それを見つけていただきありがとうございます。私はそれを修正しました。 –