0

在 Eclipse 中运行动态 Web 项目时遇到问题。我创建了一个 Maven 项目(archtype - webapp),然后通过添加 maven-eclipse-plugin(2.9 版)在其中添加了 DWP 行为。我在 POM 文件中添加了我的项目依赖项,如下所示

<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>au.com.fairfaxdigital</groupId>
    <artifactId>accessloganalyzer</artifactId>
    <packaging>war</packaging>
    <version>1.0-SNAPSHOT</version>
    <name>accessloganalyzer Maven Webapp</name>
    <url>http://maven.apache.org</url>  
    <dependencies>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.0.1</version>
        </dependency>
        <dependency>
            <groupId>net.sourceforge.wurfl</groupId>
            <artifactId>wurfl</artifactId>
            <version>1.4</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.8</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <repositories>
        <repository>
            <id>scientiamobile.public</id>
            <name>Scientia Mobile Public repository</name>
            <url>http://dev.scientiamobile.com/nexus/content/repositories/public-releases/</url>
        </repository>
    </repositories>
    <build>
        <finalName>accessloganalyzer</finalName>

        <plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.6</source>
                    <target>1.6</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-eclipse-plugin</artifactId>
                <version>2.9</version>
                <configuration>
                    <projectNameTemplate>accessloganalyzer-${project.version}</projectNameTemplate>
                    <downloadSources>true</downloadSources>
                    <downloadJavadocs>true</downloadJavadocs>
                    <wtpmanifest>true</wtpmanifest>
                    <wtpapplicationxml>true</wtpapplicationxml>
                    <wtpversion>2.0</wtpversion>
                    <manifest>${basedir}/src/main/resources/META-INF/MANIFEST.MF</manifest>
                </configuration>
            </plugin>

        </plugins>
    </build>
</project>

然后我使用 maven 命令(全新安装)构建项目。我可以在目标文件夹中看到生成的战争文件。当尝试在eclipse中的tomcat上运行这个应用程序(项目->右键单击->运行一个服务器)时,tomcat启动时出错。

严重:向 net.sourceforge.wurfl.core.web.WURFLServletContextListener 类的侦听器实例发送上下文初始化事件的异常 java.lang.NoClassDefFoundError: org/apache/commons/lang/StringUtils at net.sourceforge.wurfl.core.web.WURFLServletContextListener .contextInitialized(WURFLServletContextListener.java:81) 在 org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4765) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5260) 在 org. apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:866) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase. java:842) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:615) 在 org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:649) 在 org.apache.catalina.startup.HostConfig$DeployDescriptor.run(HostConfig.java:1581) 在 java.util.concurrent.Executors $RunnableAdapter.call(Executors.java:441) at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303) at java.util.concurrent.FutureTask.run(FutureTask.java:138) at java. util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) 在 java.lang.Thread.run(Thread.java:662)引起:java.lang.ClassNotFoundException: org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1688) 中 org.apache.catalina.loader.WebappClassLoader 中的 org.apache.commons.lang.StringUtils。loadClass(WebappClassLoader.java:1533) ... 15 更多 开始 Introspector 初始化...

当我查看 tomcat 运行应用程序的 Eclipse 文件夹时(C:\Deepak\Study\Dev\Practicals\workspace.metadata.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps\accessloganalyzer-1.0-SNAPSHOT ),我没有找到我在项目中使用的第三方库 wurfl.1.4.jar 的任何依赖项(包括错误中引用的 commons-lang)。

wurfl 库使用以下依赖项,这些依赖项在 WEB-INF/lib 中不存在,因此导致问题

  • commons-collections-3.2.1
  • commons-lang-2.6
  • 杰克逊核心asl-1.8.2
  • 杰克逊-映射器-asl-1.8.2
  • logback-经典-0.9.28
  • logback-core-0.9.28
  • slf4j-api-1.6.1

任何人都可以指出我错过了为什么这些传递依赖项没有被复制到应用程序 WAR 文件的 WEB-INF/lib 文件夹中吗?

4

1 回答 1

1

安装m2e wtp插件。这个插件可以从 Eclipse Marketplace 安装(Help -> Eclipse Marketplace...)。这应该让你大部分时间都在那里。然后,您应该在您期望的地方看到您的依赖项。

于 2012-07-23T20:42:48.020 回答