2

私が開発したプラグインで ClassNotFoundException がスローされています。見つけられないクラスは確実に存在し、関連するプロジェクトは実行中のプロジェクトの pom.xml ファイルに次のように依存関係として含まれています。

<dependency>
    <groupId>com.example</groupId>
    <artifactId>project-one</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>

私のプラグインは、次のように実行中の pom.xml に含まれています。

<build>
<plugins>
 <plugin>
   <groupId>com.example</groupId>
                <artifactId>project-two-plugin</artifactId>
                <version>1.0</version>
                <executions>
                    <execution>
                        <configuration>
                           <customSettingOne>
                               setting
                           </customSettingOne>
                        </configuration>
                        <phase>prepare-package</phase>
                        <goals>
                            <goal>some-task</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

        </plugins>
    </build>

私のプラグインクラスは次のとおりです。

/**
 *  @goal some-task
 *
 *  @requiresDependencyResolution compile
 */

public class MyPluginMojo extends AbstractMojo {

    /**
     * Directory to save the CSV files to.
     *
     * @parameter alias="customSettingOne"
     * @required
     */
    private File customSettingOne;

}

私はこのコードを使用して試しました:

Apache Maven 2.2.1 (r801777; 2009-08-06 20:16:01+0100)

およびEclipse m2eで使用される組み込みバージョン

Embedded (3.0.2/1.0.200.20111228-1245

プラグイン コードが ProjectOne からクラスをロードしようとすると、ClassNotFoundException が発生します。

どうすればこの問題の根底にたどり着くことができるか、誰にもアイデアがありますか? プラグインで使用されているクラスパスを検査またはダンプすることは可能ですか?

4

1 に答える 1

6

私は最初にここをチェックします:

Mavenクラスローディングのガイド

それでも問題が解決しない場合は、次のような診断コードを少し使用してください。

package stackoverflow;

import java.net.URL;
import java.net.URLClassLoader;

public class PrintClassLoader {
    public static void main(String[] args) {
        PrintClassLoader pcl = new PrintClassLoader();
        pcl.printClassLoader(pcl.getClass().getClassLoader());
    }

    public void printClassLoader(ClassLoader classLoader) {
        if (null == classLoader) {
            return;
        }
        System.out.println("--------------------");
        System.out.println(classLoader);
        if (classLoader instanceof URLClassLoader) {
            URLClassLoader ucl = (URLClassLoader) classLoader;
            int i = 0;
            for (URL url : ucl.getURLs()) {
                System.out.println("url[" + (i++) + "]=" + url);
            }
        }
        printClassLoader(classLoader.getParent());
    }
}

たとえば、次のように出力されます。

--------------------
sun.misc.Launcher$AppClassLoader@35ce36
url[0]=file:/D:/dev/workspaces/3.6/all/Z_temp/target/classes/
url[1]=file:/D:/dev/.m2/repository/javax/mail/mail/1.4/mail-1.4.jar
url[2]=file:/D:/dev/.m2/repository/javax/activation/activation/1.1/activation-1.1.jar
url[3]=file:/D:/dev/.m2/repository/commons-io/commons-io/2.1/commons-io-2.1.jar
--------------------
sun.misc.Launcher$ExtClassLoader@757aef
url[0]=file:/C:/java/jdk/jdk1.6.0_31/jre/lib/ext/dnsns.jar
url[1]=file:/C:/java/jdk/jdk1.6.0_31/jre/lib/ext/localedata.jar
url[2]=file:/C:/java/jdk/jdk1.6.0_31/jre/lib/ext/sunjce_provider.jar
url[3]=file:/C:/java/jdk/jdk1.6.0_31/jre/lib/ext/sunmscapi.jar
url[4]=file:/C:/java/jdk/jdk1.6.0_31/jre/lib/ext/sunpkcs11.jar
于 2012-06-11T18:39:02.983 に答える