在Servlet 3.0应用程序

时间:2016-02-08 15:06:29

标签: java servlets log4j2

我正在尝试在我的Servlet 3.0 Web应用程序中使用Log4j2。即使按照官方文档配置了所有内容,我也无法看到日志。

这是我的web.xml:

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

    <display-name>myapplication</display-name>

    <context-param>
        <param-name>isLog4jAutoInitializationDisabled</param-name>
        <param-value>true</param-value>
    </context-param>
    <context-param>
        <param-name>isLog4jContextSelectorNamed</param-name>
        <param-value>true</param-value>
    </context-param>

    <context-param>
        <param-name>log4jConfiguration</param-name>
        <param-value>log4j2.xml</param-value>
    </context-param>

    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
    </welcome-file-list>
</web-app>

我已将log4j2.xml文件放在WEB-INF / classes中:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="INFO">
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
        </Console>
        <File name="MyFile" fileName="myapplication.log" immediateFlush="true" append="false">
            <PatternLayout pattern="%d{yyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
        </File>
    </Appenders>
    <Loggers>
        <Root level="info">
            <AppenderRef ref="Console" />
            <AppenderRef ref="MyFile"/>
        </Root>
    </Loggers>
</Configuration>

这就是我在课堂上调用logger的方法:

final static Logger LOGGER = Logger.getLogger(MyClass.class);
LOGGER.info("Logging works");

请告诉我我做错了什么。我甚至尝试过硬编码log4j2.xml的直接路径,但它仍然不起作用。

1 个答案:

答案 0 :(得分:0)

使用Servlet 3.0,将isLog4jAutoInitializationDisabled设置为 false ,或将其删除,它应该有效。

如果您将其保留为 true ,则您需要添加其他步骤和内容web.xml

  

禁用自动初始化后,必须像您一样初始化Log4j   将是一个Servlet 2.5 Web应用程序。

  

如果您在Servlet 2.5 Web应用程序中使用Log4j,或者如果您使用   已禁用自动初始化   isLog4jAutoInitializationDisabled上下文参数,你必须   在中配置Log4jServletContextListener和Log4jServletFilter   部署描述符或以编程方式。

请参阅此处Log4j2 and Servlet 3.0