【问题标题】:How to mapping Logger into spring J2ee application?如何将 Logger 映射到 Spring J2ee 应用程序?
【发布时间】:2015-04-17 06:20:09
【问题描述】:

我有一个带有 Spring MVC 的简单 J2ee 应用程序。现在我想插入一个记录器文件。所以我在springmvc-servlet中插入了这段代码:

<bean id="lo4gjConfigurator" class="com.springmvcapp.log.LoggerFactory">
       <property name="logReInit">
        <value>@logReInit@</value>
       </property>  
       <property name="fileName">
        <value>log4j.xml</value>
       </property> 
    </bean>

但是如果我在服务器启动时尝试加载页面,我会遇到这个错误

javax.servlet.ServletException: Servlet.init() for servlet springmvcapp threw exception
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
    org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936)
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004)
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
    org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312)
    java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    java.lang.Thread.run(Unknown Source)

root cause

org.springframework.beans.factory.CannotLoadBeanClassException: Error loading class [com.springmvcapp.log.LoggerFactory] for bean with name 'lo4gjConfigurator' defined in ServletContext resource [/WEB-INF/springmvcapp-servlet.xml]: problem with class file or dependent class; nested exception is java.lang.NoClassDefFoundError: org/aopalliance/intercept/MethodInterceptor
    org.springframework.beans.factory.support.AbstractBeanFactory.resolveBeanClass(AbstractBeanFactory.java:1269)
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.predictBeanType(AbstractAutowireCapableBeanFactory.java:581)
    org.springframework.beans.factory.support.AbstractBeanFactory.isFactoryBean(AbstractBeanFactory.java:1335)
    org.springframework.beans.factory.support.AbstractBeanFactory.isFactoryBean(AbstractBeanFactory.java:901)
    org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:607)
    org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:932)
    org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:479)
    org.springframework.web.servlet.FrameworkServlet.configureAndRefreshWebApplicationContext(FrameworkServlet.java:652)
    org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:600)
    org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:666)
    org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:519)
    org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:460)
    org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:136)
    javax.servlet.GenericServlet.init(GenericServlet.java:160)
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
    org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936)
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004)
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
    org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312)
    java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    java.lang.Thread.run(Unknown Source)

编辑: 这是 log4j.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

    <appender name="ROOT_APPENDER" class="capacita.apache.log4j.RollingFileAppender">
        <param name="file" value="@log4j.logs@/pcs.log"/>
        <param name="MaxFileSize" value="50MB"/>
        <param name="MaxBackupIndex" value="5"/>
        <layout class="capacita.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d{dd/MM/yyyy HH:mm:ss} | %X{serverInstance} | %p | %X{sessionId} | %C{1} | %M | %m%n"/>
        </layout>
    </appender>

    <appender name="ERROR_APPENDER" class="capacita.apache.log4j.RollingFileAppender">
        <param name="file" value="@log4j.logs@/err_pcs.log"/>
        <param name="MaxFileSize" value="50MB"/>
        <param name="MaxBackupIndex" value="5"/>
        <layout class="capacita.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d{dd/MM/yyyy HH:mm:ss} | %X{serverInstance} | %p | %X{sessionId} | %m%n"/>
        </layout>
    </appender>

    <appender name="LOGIN_APPENDER" class="com.springmvcapp.log.RollingFileAppender">
        <param name="file" value="@log4j.logs@/login-pcs.log"/>
        <rollingPolicy class="com.springmvcapp.log.TimeBasedRollingPolicy">
            <param name="fileNamePattern" value="@log4j.logs@/log-pcs-%d{yyyyMMdd}.log"/>
        </rollingPolicy>
        <layout class="capacita.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d{dd-MM-yyyy HH:mm:ss}|%m%n"/>
        </layout>
    </appender>

    <appender name="CONSOLE_APPENDER" class="capacita.apache.log4j.ConsoleAppender">
        <layout class="capacita.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="[%d{HH:mm:ss}] [%p] [%C{1}].[%M](%L) %m%n"/>
        </layout>
    </appender>

    <appender name="AXIS_APPENDER" class="capacita.apache.log4j.RollingFileAppender">
        <param name="file" value="@log4j.logs@/axis_pcs.log"/>
        <param name="MaxFileSize" value="50MB"/>
        <param name="MaxBackupIndex" value="5"/>
        <layout class="capacita.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d{dd/MM/yyyy HH:mm:ss} | %X{serverInstance} | %p | %X{sessionId} | %C{1} | %M | %m%n"/>
        </layout>
    </appender>

    <appender name="DAEMON_APPENDER" class="capacita.apache.log4j.RollingFileAppender">
        <param name="file" value="@log4j.logs@/daemon_pcs.log"/>
        <param name="MaxFileSize" value="50MB"/>
        <param name="MaxBackupIndex" value="5"/>
        <layout class="capacita.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d{dd/MM/yyyy HH:mm:ss} | %X{serverInstance} | %p | %X{sessionId} | %C{1} | %M | %m%n"/>
        </layout>
    </appender>

    <category name="log4j.logger.org.apache.axis.SOAPPart">
        <priority value="DEBUG"/>
        <appender-ref ref="AXIS_APPENDER"/>
    </category>

    <logger name="AXIS">
        <level value="DEBUG"/>
        <appender-ref ref="AXIS_APPENDER"/>
    </logger>


    <logger name="org.springframework">
        <level value="ERROR"/>
        <appender-ref ref="ROOT_APPENDER"/>
    </logger>


    <logger name="ERROR">
        <level value="ERROR"/>
        <appender-ref ref="ERROR_APPENDER"/>
        <!--appender-ref ref="CONSOLE_APPENDER"/-->
    </logger>

    <logger name="ROOT">
        <level value="DEBUG"/>
        <level value="INFO"/>
        <appender-ref ref="ROOT_APPENDER"/>
        <appender-ref ref="CONSOLE_APPENDER"/>
        <!--appender-ref ref="CONSOLE_APPENDER"/ -->
    </logger>

    <logger name="LOGIN">
        <level value="DEBUG"/>
        <appender-ref ref="LOGIN_APPENDER"/>
        <!--appender-ref ref="CONSOLE_APPENDER"/-->
    </logger>

    <logger name="DAEMON">
        <level value="DEBUG"/>
        <appender-ref ref="DAEMON_APPENDER"/>
        <!--appender-ref ref="CONSOLE_APPENDER"/-->
    </logger>
</log4j:configuration>

【问题讨论】:

  • 我已经修复了错误,我已经更改了 log4j 的库,并且我已经插入了这一行代码以在 log4j.xml 中创建一个记录器文件:“C:/webapps/err_pcs.log”所以现在,当我尝试在记录器文件上写入时,我没有错误,我没有任何错误,但 err_pcs.log 没有创建。我的错误在哪里?

标签: spring jakarta-ee log4j


【解决方案1】:

尝试使用 logback.xml 很容易实现。 http://logback.qos.ch/reasonsToSwitch.html

【讨论】:

  • 你能发布 log4j.xml 吗?
  • 您不必在 servlet 中插入该代码,使用此 xml 就足够了。 log4j-config.xml。 howtodoinjava.com/2013/04/08/…
  • 对于nole,我已经编辑了我的问题,并且我已经插入了log4j.xml的代码
【解决方案2】:

以 spring 为例,您有 src/main/java,而在其他源文件夹中,您有 src/main/resources,并且在该文件夹中您必须发布 log4j.xml

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2015-02-07
    • 1970-01-01
    • 2011-11-26
    • 2019-05-13
    • 1970-01-01
    • 2021-04-18
    • 2015-04-06
    相关资源
    最近更新 更多