什么是在spring MVC 3.0+中添加log4j的基于等效代码的配置

时间:2013-10-15 08:39:51

标签: java spring spring-mvc

我正在将Spring MVC项目迁移到基于代码的配置,但不确定如何添加监听器,

这是我的web.xml中的内容

<context-param>
    <param-name>log4jConfigLocation</param-name>
    <param-value>WEB-INF/spring/log4j.xml</param-value>
</context-param>

<listener>
    <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>

这是我的init类:

@Order(1)
public class Initializer extends
        AbstractAnnotationConfigDispatcherServletInitializer {

    @Override
    protected Class<?>[] getRootConfigClasses() {
        return new Class[] { RootConfig.class, SecurityConfig.class };
    }

    @Override
    protected Class<?>[] getServletConfigClasses() {
        return new Class[] { WebConfig.class };
    }

    @Override
    protected String[] getServletMappings() {
        return new String[] { "/" };
    }

}

我检查了AbstractAnnotationConfigDispatcherServletInitializer的声明, 并尝试实施onStartUp(),如下所示,但它抱怨addListener未找到。

@Override
    public void onStartup(ServletContext container) throws ServletException {
        org.springframework.web.util.Log4jConfigListener log4jConfigListener = new org.springframework.web.util.Log4jConfigListener();
        container.addListener(log4jConfigListener);
        super.onStartup(container);
    }

1 个答案:

答案 0 :(得分:0)

<listener>元素来自web.xml,而不是来自spring配置。

你在这里想要实现的是programmaticaly添加一个Listener。这是Servlet API 3.0的一项功能。你必须使用servlet-api 3.0才能做你想做的事。

例如,Tomcat 6+ Jetty 8+等支持Servlet api 3.0