web-dev-qa-db-ja.com

org.Apache.maven.plugins:maven-war-plugin:2.1.1:warの実行中に必要なクラスが欠落していました

これは、私のクリーンインストール-xの結果です。

[INFO] Scanning for projects...
[INFO]                                                                         
[INFO] ------------------------------------------------------------------------
[INFO] Building test Maven Webapp 0.0.1-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO] 
[INFO] --- maven-clean-plugin:2.5:clean (default-clean) @ test ---
[INFO] Deleting C:\Users\utopcu\workspace\test\target
[INFO] 
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ test ---
[WARNING] Using platform encoding (Cp1254 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] Copying 0 resource
[INFO] 
[INFO] --- maven-compiler-plugin:2.5.1:compile (default-compile) @ test ---
[INFO] No sources to compile
[INFO] 
[INFO] --- maven-resources-plugin:2.6:testResources (default-testResources) @ test ---
[WARNING] Using platform encoding (Cp1254 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] skip non existing resourceDirectory C:\Users\utopcu\workspace\test\src\test\resources
[INFO] 
[INFO] --- maven-compiler-plugin:2.5.1:testCompile (default-testCompile) @ test ---
[INFO] No sources to compile
[INFO] 
[INFO] --- maven-surefire-plugin:2.12.4:test (default-test) @ test ---
[INFO] No tests to run.
[INFO] 
[INFO] --- maven-war-plugin:2.1.1:war (default-war) @ test ---
[WARNING] Error injecting: org.Apache.maven.plugin.war.WarMojo
Java.lang.NoClassDefFoundError: org/Apache/maven/shared/filtering/MavenFilteringException
    at Java.lang.Class.getDeclaredConstructors0(Native Method)
    at Java.lang.Class.privateGetDeclaredConstructors(Class.Java:2483)
    at Java.lang.Class.getDeclaredConstructors(Class.Java:1891)
    at com.google.inject.spi.InjectionPoint.forConstructorOf(InjectionPoint.Java:245)
    at com.google.inject.internal.ConstructorBindingImpl.create(ConstructorBindingImpl.Java:99)
    at com.google.inject.internal.InjectorImpl.createUninitializedBinding(InjectorImpl.Java:653)
    at com.google.inject.internal.InjectorImpl.createJustInTimeBinding(InjectorImpl.Java:863)
    at com.google.inject.internal.InjectorImpl.createJustInTimeBindingRecursive(InjectorImpl.Java:790)
    at com.google.inject.internal.InjectorImpl.getJustInTimeBinding(InjectorImpl.Java:278)
    at com.google.inject.internal.InjectorImpl.getBindingOrThrow(InjectorImpl.Java:210)
    at com.google.inject.internal.InjectorImpl.getProviderOrThrow(InjectorImpl.Java:986)
    at com.google.inject.internal.InjectorImpl.getProvider(InjectorImpl.Java:1019)
    at com.google.inject.internal.InjectorImpl.getProvider(InjectorImpl.Java:982)
    at com.google.inject.internal.InjectorImpl.getInstance(InjectorImpl.Java:1032)
    at org.Eclipse.sisu.reflect.AbstractDeferredClass.get(AbstractDeferredClass.Java:44)
    at com.google.inject.internal.ProviderInternalFactory.provision(ProviderInternalFactory.Java:86)
    at com.google.inject.internal.InternalFactoryToInitializableAdapter.provision(InternalFactoryToInitializableAdapter.Java:55)
    at com.google.inject.internal.ProviderInternalFactory$1.call(ProviderInternalFactory.Java:70)
    at com.google.inject.internal.ProvisionListenerStackCallback$Provision.provision(ProvisionListenerStackCallback.Java:100)
    at org.Eclipse.sisu.plexus.lifecycles.PlexusLifecycleManager.onProvision(PlexusLifecycleManager.Java:134)
    at com.google.inject.internal.ProvisionListenerStackCallback$Provision.provision(ProvisionListenerStackCallback.Java:109)
    at com.google.inject.internal.ProvisionListenerStackCallback.provision(ProvisionListenerStackCallback.Java:55)
    at com.google.inject.internal.ProviderInternalFactory.circularGet(ProviderInternalFactory.Java:68)
    at com.google.inject.internal.InternalFactoryToInitializableAdapter.get(InternalFactoryToInitializableAdapter.Java:47)
    at com.google.inject.internal.InjectorImpl$2$1.call(InjectorImpl.Java:997)
    at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.Java:1047)
    at com.google.inject.internal.InjectorImpl$2.get(InjectorImpl.Java:993)
    at com.google.inject.Scopes$1$1.get(Scopes.Java:59)
    at org.Eclipse.sisu.locators.LazyBeanEntry.getValue(LazyBeanEntry.Java:82)
    at org.Eclipse.sisu.plexus.locators.LazyPlexusBean.getValue(LazyPlexusBean.Java:52)
    at org.codehaus.plexus.DefaultPlexusContainer.lookup(DefaultPlexusContainer.Java:259)
    at org.codehaus.plexus.DefaultPlexusContainer.lookup(DefaultPlexusContainer.Java:251)
    at org.Apache.maven.plugin.internal.DefaultMavenPluginManager.getConfiguredMojo(DefaultMavenPluginManager.Java:459)
    at org.Apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.Java:97)
    at org.Apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.Java:208)
    at org.Apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.Java:153)
    at org.Apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.Java:145)
    at org.Apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.Java:84)
    at org.Apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.Java:59)
    at org.Apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.Java:183)
    at org.Apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.Java:161)
    at org.Apache.maven.DefaultMaven.doExecute(DefaultMaven.Java:318)
    at org.Apache.maven.DefaultMaven.execute(DefaultMaven.Java:153)
    at org.Apache.maven.cli.MavenCli.execute(MavenCli.Java:555)
    at org.Apache.maven.cli.MavenCli.doMain(MavenCli.Java:214)
    at org.Apache.maven.cli.MavenCli.main(MavenCli.Java:158)
    at Sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at Sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.Java:57)
    at Sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.Java:43)
    at Java.lang.reflect.Method.invoke(Method.Java:606)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.Java:290)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.Java:230)
    at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.Java:414)
    at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.Java:357)
    at org.codehaus.classworlds.Launcher.main(Launcher.Java:47)
Caused by: Java.lang.ClassNotFoundException: org.Apache.maven.shared.filtering.MavenFilteringException
    at org.codehaus.plexus.classworlds.strategy.SelfFirstStrategy.loadClass(SelfFirstStrategy.Java:50)
    at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClass(ClassRealm.Java:244)
    at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClass(ClassRealm.Java:230)
    ... 55 more
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 3.342s
[INFO] Finished at: Mon Aug 26 14:09:27 EEST 2013
[INFO] Final Memory: 11M/105M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.Apache.maven.plugins:maven-war-plugin:2.1.1:war (default-war) on project test: Execution default-war of goal org.Apache.maven.plugins:maven-war-plugin:2.1.1:war failed: A required class was missing while executing org.Apache.maven.plugins:maven-war-plugin:2.1.1:war: org/Apache/maven/shared/filtering/MavenFilteringException
[ERROR] -----------------------------------------------------
[ERROR] realm =    plugin>org.Apache.maven.plugins:maven-war-plugin:2.1.1
[ERROR] strategy = org.codehaus.plexus.classworlds.strategy.SelfFirstStrategy
[ERROR] urls[0] = file:/C:/Users/utopcu/.m2/repository/org/Apache/maven/plugins/maven-war-plugin/2.1.1/maven-war-plugin-2.1.1.jar
[ERROR] urls[1] = file:/C:/Users/utopcu/.m2/repository/org/Apache/maven/reporting/maven-reporting-api/2.0.6/maven-reporting-api-2.0.6.jar
[ERROR] urls[2] = file:/C:/Users/utopcu/.m2/repository/org/Apache/maven/doxia/doxia-sink-api/1.0-alpha-7/doxia-sink-api-1.0-alpha-7.jar
[ERROR] urls[3] = file:/C:/Users/utopcu/.m2/repository/commons-cli/commons-cli/1.0/commons-cli-1.0.jar
[ERROR] urls[4] = file:/C:/Users/utopcu/.m2/repository/org/codehaus/plexus/plexus-interactivity-api/1.0-alpha-4/plexus-interactivity-api-1.0-alpha-4.jar
[ERROR] urls[5] = file:/C:/Users/utopcu/.m2/repository/org/Apache/maven/maven-archiver/2.4.1/maven-archiver-2.4.1.jar
[ERROR] urls[6] = file:/C:/Users/utopcu/.m2/repository/org/codehaus/plexus/plexus-archiver/1.2/plexus-archiver-1.2.jar
[ERROR] urls[7] = file:/C:/Users/utopcu/.m2/repository/org/codehaus/plexus/plexus-io/1.0.1/plexus-io-1.0.1.jar
[ERROR] urls[8] = file:/C:/Users/utopcu/.m2/repository/org/codehaus/plexus/plexus-interpolation/1.13/plexus-interpolation-1.13.jar
[ERROR] urls[9] = file:/C:/Users/utopcu/.m2/repository/junit/junit/3.8.1/junit-3.8.1.jar
[ERROR] urls[10] = file:/C:/Users/utopcu/.m2/repository/com/thoughtworks/xstream/xstream/1.3.1/xstream-1.3.1.jar
[ERROR] urls[11] = file:/C:/Users/utopcu/.m2/repository/xpp3/xpp3_min/1.1.4c/xpp3_min-1.1.4c.jar
[ERROR] urls[12] = file:/C:/Users/utopcu/.m2/repository/org/codehaus/plexus/plexus-utils/2.0.5/plexus-utils-2.0.5.jar
[ERROR] urls[13] = file:/C:/Users/utopcu/.m2/repository/org/Apache/maven/shared/maven-filtering/1.0-beta-2/maven-filtering-1.0-beta-2.jar
[ERROR] Number of foreign imports: 1
[ERROR] import: Entry[import  from realm ClassRealm[maven.api, parent: null]]
[ERROR] 
[ERROR] -----------------------------------------------------: org.Apache.maven.shared.filtering.MavenFilteringException
[ERROR] -> [Help 1]
[ERROR] 
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.Apache.org/confluence/display/MAVEN/PluginContainerException

そして、ここに私の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>trest</groupId>
    <artifactId>test</artifactId>
    <packaging>war</packaging>
    <version>0.0.1-SNAPSHOT</version>
    <name>test Maven Webapp</name>
    <url>http://maven.Apache.org</url>
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.Apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.1.1</version>
            </plugin>
        </plugins>
    </build>
</project>

リポジトリを削除して、もう一度インストールしようとしました。私は常にこのエラーを受け取りました。助けが必要なようです。 mojoプラグインが壊れていると思いますが、何度か再インストールしました。助言がありますか?

17
Ufuk Alp Topçu

クラスorg.Apache.maven.shared.filtering.MavenFilteringException に存在する file:/C:/Users/utopcu/.m2/repository/org/Apache/maven/shared/maven-filtering/1.0-beta-2/maven-filtering-1.0-beta-2.jar

エラーメッセージは、そうではないことを示唆しています。 JARが何らかの理由で破損した可能性があります。

また、バージョン1.0-beta-2 から来た;私が持っています 1.0私のディスク。バージョンを試す2.3のWARプラグイン。

15
Aaron Digulla

〜/ .m2/repository/org/Apache/mavenでmavenフォルダーを削除し、プロジェクトを再度ビルドして、mavenライブラリーを強制的にダウンロードしてみてください。このJava.lang.NoClassDefFoundError:org/Apache/maven/shared/filtering/MavenFilteringExceptionに最後に直面したとき、これはうまくいきました。

12
Eduardo Costa

同じ問題に直面し、Mavenを3.0.4から3.1.1にアップグレードすることで解決しました。 v3.1.1またはそれ以上のバージョンがある場合は試してください

4
Subash P

これでエラーが修正されます

<plugin>
     <groupId>org.Apache.maven.plugins</groupId>
     <artifactId>maven-resources-plugin</artifactId>
     <version>2.7</version>
     <dependencies>
         <dependency>
             <groupId>org.Apache.maven.shared</groupId>
             <artifactId>maven-filtering</artifactId>
             <version>1.3</version>
          </dependency>
      </dependencies>
</plugin>
3
sabbir

pom.xmlファイルにmaven-resources-pluginを追加する必要があります。 〜/ .m2/repositoryを削除しても、常に機能するとは限りません。

        <plugins>
            <plugin>
                <groupId>org.Apache.maven.plugins</groupId>
                <artifactId>maven-resources-plugin</artifactId>
                <version>2.4</version>
            </plugin>
        </plugins>

ここでプロジェクトを再度ビルドします。成功するはずです!

これは、バージョンタグ(欠落している)をmaven-war-pluginに追加した後にも起こりました(デフォルトではどのバージョンが使用されているかわからず、最新の2.6に変更しました)。ビルドを再度成功させるには、.m2 /リポジトリを消去する必要がありました。

私は最初に(リポジトリ内の)maven-filteringフォルダをクリーンアップしようとしましたが、MavenFilterExceptionの代わりにArchiverExceptionを取得していました。そこで、ローカルリポジトリが破損していると判断し(バージョンアップグレードのため?)、すべてを削除しました。

それは私のためにそれを修正しました。地元のレポをきれいにしてください。

2
user2560528

以下の私の解決策は、デフォルトのMavenリポジトリにアクセスできない場合(ファイアウォールなどが原因)です。

デフォルトのリポジトリにアクセスできない場合、適切なローカル<pluginRepository>をsettings.xmlで指定する必要があります。ローカルアーティファクトリポジトリと同じ場合、プラグインjarを見つけるために<pluginRepositories>セクションに追加する必要があります。通常の<repositories>セクションは、プラグインjarの取得には使用されません。

しかし、私の場合、問題はそのセクションで複数のプラグインリポジトリが定義されているという事実が原因でした。

リストの最初のリポジトリには、必要なmavenフィルタリングjarが含まれていませんでした。

最初の定義にmaven-filteringが含まれるようにするには、<pluginRepository>定義の順序を変更する必要がありました。

リポジトリ定義を変更するには、通常、〜/ .m2/repositoryをクリーンアップして新たに開始する必要があります。

0
ATrubka