1

私のコードは、Eclipse で Java アプリケーションとして実行すると機能しますが、maven-exec プラグインを使用して maven install を実行すると失敗します。構成ファイルが見つからないために失敗することはわかっていますが、どうすればよいですか?

maven-exec プラグインを除外すると、正常にビルドされ、依存関係のある jar ファイルを実行できます。

public class App 
{
    public static void main( String[] args )
    {
        System.out.println( "... starting DomParser" );
        System.out.println( "... inside app" );

        DOMParser.loadXML("/config.xml");

        System.out.println( "... ending DomParser" );
    }
}

簡略化された DomParser クラスは次のとおりです。

static SAXBuilder builder = new SAXBuilder();
static Document doc;
public static void loadXML(String path) {
    java.net.URL url = DOMParser.class.getClass().getResource(path);
    doc = builder.build(url);
    root = doc.getRootElement();
}

これは 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.ericsson.ci.simnet</groupId>
    <artifactId>domparser</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>domparser</name>
    <url>http://maven.apache.org</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.0</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.14</version>
        </dependency>

        <dependency>
            <groupId>org.jdom</groupId>
            <artifactId>jdom2</artifactId>
            <version>2.0.5</version>
        </dependency>

    </dependencies>

    <build>

        <!-- <finalName>${project.name}</finalName> -->

        <plugins>
            <!-- Tell maven to compile using Java 1.7 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.1</version>
                <configuration>
                    <source>1.6</source>
                    <target>1.6</target>
                </configuration>
            </plugin>

            <plugin>
                <groupId>org.codehaus.mojo</groupId>
                <artifactId>exec-maven-plugin</artifactId>
                <version>1.2.1</version>
                <executions>
                    <execution>
                        <phase>test</phase>
                        <goals>
                            <goal>java</goal>
                        </goals>
                        <configuration>
                            <mainClass>com.x.ci.simnet.domparser.App</mainClass>
                            <arguments>
                                <argument></argument>
                            </arguments>
                        </configuration>
                    </execution>
                </executions>
            </plugin>

            <!-- to bundle necessary classes of dependent JAR files -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>1.5</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <transformers>
                                <transformer
                                    implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>com.x.ci.simnet.domparser.App</mainClass>
                                </transformer>
                            </transformers>
                            <!--<shadedArtifactAttached>true</shadedArtifactAttached> -->
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

</project>

エラーはここにあります:

[ERROR] Failed to execute goal org.codehaus.mojo:exec-maven-plugin:1.2.1:java (default) on project domparser: An exception occured while executing the Java class. null: InvocationTargetException: NullPointerException -> [Help 1]
4

1 に答える 1

1

夜の長い時間の後、私は解決策を見つけました。助けてくれてありがとう。

DomParser クラス コードを以下のように置き換えました。

import org.jdom2.input.SAXBuilder;
import org.jdom2.Document;

public class DOMParser {

static SAXBuilder builder = new SAXBuilder();
static Document doc;
...
...

public static void loadXML(String path) {
    ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
    java.net.URL url = classLoader.getResource(path);
    doc = builder.build(url);
    root = doc.getRootElement();
}

したがって、重要なトリックは、次のコード行を使用することでした。

ClassLoader classLoader = Thread.currentThread().getContextClassLoader();

これにより、次の方法でアプリケーションを実行できます

  1. Eclipse > Java アプリケーションとして実行
  2. maven exec プラグイン
  3. Maven Shade プラグインを含む実行可能 jar

これが、他の人が将来同様の問題を抱えているのに役立つことを願っています。

アップデート:

App クラスのコードも少し変更したことを忘れていました。たった一行。以下のようにファイル anme をスラッシュなしで渡します。

DOMParser.loadXML("config.xml"); 
于 2014-02-02T13:52:38.867 に答える