Java Tomcat找不到包含筛选器的自定义库

Java Tomcat找不到包含筛选器的自定义库,java,maven,tomcat,jar,shared-libraries,Java,Maven,Tomcat,Jar,Shared Libraries,在为Tomcat创建包含用于创建自定义日志的过滤器的库时,我做了以下工作: 编译(mvn包)一个包含单个文件过滤器的JAR库,并将其放入Tomcat的全局lib文件夹中 在Tomcat的全局web.xml文件中定义了过滤器 重新启动Tomcat以确保更改生效 收到此错误: 10-Jul-2017 15:46:32.591 SEVERE [ContainerBackgroundProcessor[StandardEngine[Catalina]]] org.apache.catalina.co

在为Tomcat创建包含用于创建自定义日志的过滤器的库时,我做了以下工作:

  • 编译(
    mvn包
    )一个包含单个文件过滤器的JAR库,并将其放入Tomcat的全局
    lib
    文件夹中
  • 在Tomcat的全局
    web.xml
    文件中定义了过滤器
  • 重新启动Tomcat以确保更改生效
收到此错误:

10-Jul-2017 15:46:32.591 SEVERE [ContainerBackgroundProcessor[StandardEngine[Catalina]]] org.apache.catalina.core.StandardContext.filterStart Exception starting filter [ReqRespDumpFilter]
 java.lang.NoClassDefFoundError: Could not initialize class com.example.ReqRespDumpFilter
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:120)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:262)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:108)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4481)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5121)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
    at org.apache.catalina.core.StandardContext.reload(StandardContext.java:3690)
    at org.apache.catalina.startup.HostConfig.reload(HostConfig.java:1404)
    at org.apache.catalina.startup.HostConfig.checkResources(HostConfig.java:1377)
    at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1613)
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:304)
    at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:123)
    at org.apache.catalina.core.ContainerBase.backgroundProcess(ContainerBase.java:1172)
    at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1394)
    at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.processChildren(ContainerBase.java:1398)
    at org.apache.catalina.core.ContainerBase$ContainerBackgroundProcessor.run(ContainerBase.java:1366)
    at java.lang.Thread.run(Thread.java:748)
10-Jul-2017 16:58:11.581 SEVERE [ContainerBackgroundProcessor[StandardEngine[Catalina]]] org.apache.catalina.core.StandardContext.startInternal One or more Filters failed to start. Full details will be found in the appropriate container log file
pom.xml
用于编译库:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.example</groupId>
    <artifactId>ReqRespDumpFilter</artifactId>
    <packaging>jar</packaging>
    <version>1.0-SNAPSHOT</version>
    <name>ReqRespDumpFilter Maven Webapp</name>
    <url>http://maven.apache.org</url>
    <dependencies>
        <!-- https://mvnrepository.com/artifact/javax.servlet/servlet-api -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
            <scope>provided</scope>
        </dependency>
        <!-- https://mvnrepository.com/artifact/log4j/log4j -->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.4</version>
        </dependency>
    </dependencies>
    <build>
        <finalName>ReqRespDumpFilter</finalName>
        <sourceDirectory>src</sourceDirectory>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>
您将获得:

 java.lang.NoClassDefFoundError: Could not initialize class com.example.ReqRespDumpFilter
因为此类包含
org.apache.log4j.Logger
实例的静态初始值设定项

标准Tomcat发行版中既不存在
log4j
也不存在
commons io
,因此您需要确保它们也存在于Tomcat
lib
目录中

此外,您需要将
log4j.properties/log4j.xml
文件复制/移动到tomcat
conf
目录中,以便正确配置日志记录。您可能希望在所有应用程序中提供log4j
,以便集中配置

您将获得:

 java.lang.NoClassDefFoundError: Could not initialize class com.example.ReqRespDumpFilter
因为此类包含
org.apache.log4j.Logger
实例的静态初始值设定项

标准Tomcat发行版中既不存在
log4j
也不存在
commons io
,因此您需要确保它们也存在于Tomcat
lib
目录中


此外,您需要将
log4j.properties/log4j.xml
文件复制/移动到tomcat
conf
目录中,以便正确配置日志记录。您可能希望在所有应用程序中提供log4j
,以便集中配置

您看到Tomcat/lib文件夹中的JAR了吗?我猜它在运行时不存在。JVM找不到它;它不在您认为应该在的位置。JAR应该具有您的包结构和.class文件。如果没有,那么您就有一个Maven打包问题。包类型是“jar”吗?对不起,我在前面的评论中犯了一个错误。当使用相同的命令取消归档时,自定义库与本机库具有相同的结构。这些都无关紧要。这是一个合适的罐子吗?结构是否与项目中的相同?如果没有,JVM将找不到它。这与日志记录有关,请检查stacktrace的最后一行@peter,你能检查一下删除日志代码和添加sysout吗?你看到Tomcat/lib文件夹中的JAR了吗?我猜它在运行时不存在。JVM找不到它;它不在您认为应该在的位置。JAR应该具有您的包结构和.class文件。如果没有,那么您就有一个Maven打包问题。包类型是“jar”吗?对不起,我在前面的评论中犯了一个错误。当使用相同的命令取消归档时,自定义库与本机库具有相同的结构。这些都无关紧要。这是一个合适的罐子吗?结构是否与项目中的相同?如果没有,JVM将找不到它。这与日志记录有关,请检查stacktrace的最后一行@peter,请检查删除日志代码和添加<代码>系统输出
 java.lang.NoClassDefFoundError: Could not initialize class com.example.ReqRespDumpFilter