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 コマンド (クリーン インストール) を使用してプロジェクトをビルドします。ターゲット フォルダーに生成された war ファイルが表示されます。このアプリケーションを Eclipse 内の Tomcat で実行しようとすると (プロジェクト -> 右クリック -> 1 つのサーバーを実行)、Tomcat がエラーで開始されます。

SEVERE: クラス 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. org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:866) の apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 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) で java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303) で java.util.concurrent.FutureTask.run(FutureTask.java:138) で 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-classic-0.9.28
  • logback-core-0.9.28
  • slf4j-api-1.6.1

これらの推移的な依存関係がアプリケーション WAR ファイルの WEB-INF/lib フォルダーにコピーされない理由を教えてください。

4

1 に答える 1

1

Install m2e wtp plugin. This plugin can be installed from the Eclipse Marketplace (Help -> Eclipse Marketplace...). That should get you most of the way there. You should then see your dependencies where you are expecting.

于 2012-07-23T20:42:48.020 に答える