【问题标题】:Tomcat can't find sever listener class when started from within Eclipse从 Eclipse 中启动时,Tomcat 找不到服务器侦听器类
【发布时间】:2016-01-19 20:50:18
【问题描述】:

我有一个支持 Maven 的 webapp。当我使用mvn install 运行构建时,一切看起来都很好,类位于WEB-INF/classes 下,maven 依赖项位于WEB-INF/lib 下,web.xml 文件应位于WEB-INF/ 下。

但是,当我使用 Tomcat 7.x 从 Eclipse 中进行部署时,它找不到侦听器类。 com.test.backend.BackendApplication servlet 也不会被调用,即使它在 web.xml 中配置为在启动时加载。

我注意到项目资源管理器上 Eclipse 的“已部署资源”节点下没有显示这些类,但我不知道如何让它显示在那里。

这是我得到的例外:

SEVERE: Error configuring application listener of class com.test.backend.BackendServletContextListener
java.lang.ClassNotFoundException: com.test.backend.BackendServletContextListener
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1702)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1547)
    at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:532)
    at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:514)
    at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:142)
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4876)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5455)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)
    at java.util.concurrent.FutureTask.run(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)

这是我的 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" 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>com.test.backend</display-name>
    <servlet>
        <servlet-name>jersey-servlet</servlet-name>
        <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>javax.ws.rs.Application</param-name>
            <param-value>com.test.backend.BackendApplication</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <listener>
        <listener-class>com.test.backend.BackendServletContextListener</listener-class>
    </listener>
</web-app>

我的 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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.test</groupId>
    <artifactId>backend</artifactId>
    <packaging>war</packaging>
    <version>1.0.0.0</version>

    <properties>
        <java.version>1.8</java.version>
        <maven.version>3.1.0</maven.version>
        <jersey.version>2.14</jersey.version>
        <jersey.test.version>2.15</jersey.test.version>

        <jackson.version>2.5.2</jackson.version>

        <guice.version>4.0</guice.version>
    </properties>

    <dependencies>
        ...     
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.3</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>

            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.6</version>
                <executions>
                    <execution>
                        <id>prepare-war</id>
                        <phase>prepare-package</phase>
                        <configuration>
                            <archiveClasses>true</archiveClasses>
                            <archive>
                                <manifest>
                                    <addClasspath>true</addClasspath>
                                    <classpathPrefix />
                                </manifest>
                                <manifestEntries>
                                    <Implementation-Build>${build.number}</Implementation-Build>
                                    <Implementation-Title>${project.name}</Implementation-Title>
                                    <Implementation-Vendor>RestApi.com</Implementation-Vendor>
                                    <Built-By>${user.name}</Built-By>
                                    <Built-OS>${os.name}</Built-OS>
                                    <Build-Date>${build.date}</Build-Date>
                                </manifestEntries>
                            </archive>

                            <webResources>
                                <resource>
                                    <!-- this is relative to the pom.xml directory -->
                                    <directory>./target/${project.artifactId}</directory>
                                </resource>
                            </webResources>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

</project>

非常感谢您的帮助!我搜索了几个小时,但到目前为止没有运气......

【问题讨论】:

  • 希望你没有在tomcat上手动部署应用。如果是,则从 tomcat/webapps 中删除 Web 内容并通过 eclipse 推送内容。
  • 你检查过你项目的Deployment Assembly了吗?
  • @onepotato 是的,部署程序集似乎是正确的。源文件夹 src/main/java 到 WEB-INF/classes,Maven Dependencies 到 WEB-INF/lib 和 src/main/webapp 到 /
  • @junedAhsan 不,我没有那样做。通过eclipse部署。手动部署战争实际上工作正常。
  • 差不多两年后的现在记录一下,那是什么版本的 Eclipse? Eclipse Project Facets 中设置了什么版本的 Dynamic Web Module?您是否使用m2e 来集成 maven 和 Eclipse?你搞定了吗?

标签: java eclipse maven tomcat web-applications


【解决方案1】:

右键单击 maven Web 项目,然后在部署程序集下添加“目标文件夹中包含侦听器类的文件夹”。

例如,如果ServletContextListener 实现存在于package com.company.listeners 中,则部署程序集应具有以下文件夹映射:

target//WEB-INF/classes/com/company/listeners

应该映射到

WEB-INF/classes/com/company/listeners

我认为这与 tomcat 中的类加载器层次结构和用于加载侦听器的类加载器(以及该类加载器可用的类)有关。

【讨论】:

    【解决方案2】:

    我自己也遇到了这个问题。经过大量的诅咒,我意识到我没有选中自动构建框。 (我知道我永远不应该关掉这该死的东西!)

    帮我解决了。希望这篇文章能拯救别人的理智!

    【讨论】:

      猜你喜欢
      • 2014-05-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-10-24
      • 2020-07-26
      • 2016-07-02
      相关资源
      最近更新 更多