【问题标题】:exec-maven-plugin error, even on working exampleexec-maven-plugin 错误,即使在工作示例中
【发布时间】:2015-06-15 02:43:03
【问题描述】:

EDIT5 更新/

我正在使用 Maven 3.3.3。
我只是创建了新项目并添加了编译和执行插件,作为 web 上的示例。
我尝试执行,但出现错误

[ERROR] Failed to execute goal org.codehaus.mojo:exec-maven-plugin:1.2.1:java (default-cli) on project QNAProject: An exception occured while executing the Java class. com.jadex.qna.QNAProject.App -> [Help 1]<br>
[ERROR] <br>
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.<br>
[ERROR] Re-run Maven using the -X switch to enable full debug logging.<br>
[ERROR] <br>
[ERROR] For more information about the errors and possible solutions, please read the following articles:<br>
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException<br>

我尝试了 exec-maven-plugin 版本 1.2.1 和 1.4.0,但得到了同样的错误。这是我的 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.jadex.qna</groupId>
    <artifactId>QNAProject</artifactId>
    <version>0.1</version>
    <packaging>jar</packaging>

    <name>QNAProject</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>3.8.1</version>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>2.3.2</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>
                        <goals>
                            <goal>java</goal>
                        </goals>
                    </execution>
                </executions>
                <configuration>
                    <executable>maven</executable>
                    <mainClass>com.jadex.qna.QNAProject.App</mainClass>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

我什至尝试了来自多个站点的工作示例项目,
比如

http://examples.javacodegeeks.com/enterprise-java/maven/create-java-project-with-maven-example/
http://www.mkyong.com/maven/how-to-create-a-java-project-with-maven/

但我遇到了同样的错误。

我在 C:\apache-maven-3.3.3 解压缩了 maven,并创建了环境变量 MAVEN_HOME 作为相同的路径。 有什么问题?

======================================

编辑:这是结果

嗯.. 我设置了 MAVEN_HOME,而不是 M2_HOME,因为我发现的教程说只设置它...
当然, echo %MAVEN_HOME% 显示

C:\apache-maven-3.3.3

错了吗?

我将 %MAVEN_HOME%\bin 添加到 PATH 变量中,但它也不起作用。
而且,我正在使用 eclipse

======================================

EDIT2:这是完整的日志。我使用了目标'clean exec:java -e -X'

太长了,所以我在这里上传到我的博客。
请注意,我将存储库文件夹从 C:\Users.....m2 更改为新的本地存储库文件夹 C:\apache-maven-localrepository

https://arincblossom.wordpress.com/2015/06/15/error-logs/

========================================

EDIT3:我像这样更改了 maven-compiler-plugin 设置

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.3</version>
            <configuration>
                <verbose>true</verbose>
                <fork>true</fork>
                <executable>${env.JAVA_HOME}/bin/javac</executable>
                <compilerVersion>1.5</compilerVersion>
                <!-- <source>1.8</source>
                <target>1.8</target> -->
            </configuration>
        </plugin>

它阻止了我来自mvn -e compile exec:java 的错误,但我无法使用mvn exec:java -Dexec.mainClass="com.jadex.qna.QNAProject.App" 运行

==================================

EDIT4:好的,我会从底部尝试,然后再次发布。感谢您的真诚帮助。

=======================================

编辑5

我重置了所有序列...重新安装了 eclipse、maven.. 并重新创建了项目...但没有任何效果...

我更改了 Eclipse 设置以将 JDK 路径修复为已安装的 jdk 路径,而不是 JRE 路径。然后我发现 'mvn -e clean compile exec:java' 正在工作,但我只想让 'mvn clean exec:java' 工作。它根本不起作用。

你可以在这里查看完整的源代码

https://github.com/arincblossom/MavenTestProject

这是 'mvn -e clean exec:java' 的当前控制台消息

[WARNING] 
[WARNING] Some problems were encountered while building the effective settings
[WARNING] expected START_TAG or END_TAG not TEXT (position: TEXT seen ...ore artifacts.\n   |\n   | Default: ${user.home}/.m2/repository\n  <l... @53:5)  @ C:\apache-maven-3.3.3\conf\settings.xml, line 53, column 5
[WARNING] expected START_TAG or END_TAG not TEXT (position: TEXT seen ...ore artifacts.\n   |\n   | Default: ${user.home}/.m2/repository\n  <l... @53:5)  @ C:\apache-maven-3.3.3\conf\settings.xml, line 53, column 5
[WARNING] 
[INFO] Scanning for projects...
[INFO]                                                                         
[INFO] ------------------------------------------------------------------------
[INFO] Building MavenTestProject 0.0.1-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO] 
[INFO] --- maven-clean-plugin:2.5:clean (default-clean) @ MavenTestProject ---
[INFO] Deleting C:\Users\bonavision_laptop\Desktop\Project\JadeX\MavenTestProject\MavenTestProject\target
[INFO] 
[INFO] --- exec-maven-plugin:1.4.0:java (default-cli) @ MavenTestProject ---
[WARNING] 
java.lang.ClassNotFoundException: com.jadex.qna.MavenTestProject.App
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:281)
    at java.lang.Thread.run(Thread.java:745)
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 0.900 s
[INFO] Finished at: 2015-06-15T17:42:19+09:00
[INFO] Final Memory: 8M/153M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.codehaus.mojo:exec-maven-plugin:1.4.0:java (default-cli) on project MavenTestProject: An exception occured while executing the Java class. com.jadex.qna.MavenTestProject.App -> [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/MojoExecutionException

【问题讨论】:

  • 我无法重现您的错误。我可以使用你的 POM 构建。
  • 您的.m2 目录的内容是什么?这应该位于C:\Users\RoxyEris\.m2 之类的地方。检查以确保 Codehaus 插件已下载。
  • 是的,它是 C:\User[MY DIR]\.m2 ,我也可以从 eclipse 中找到它。 (项目 - Maven 依赖项)而且,在我遇到这个问题之前,我已经为 Android 运行了 Jadex Maven 项目
  • 你试过re-run Maven with the -e switch吗?
  • 您的 JAVA_HOME 指向 Java 运行时,而 NOT 指向 JDK。

标签: java eclipse maven


【解决方案1】:

当它也与 eclipse 不兼容时会发生此问题。

试试这个

mvn clean install eclipse:eclipse

投票,如果它可以帮助其他成员

【讨论】:

    【解决方案2】:

    您发布的错误日志如下:

    java.lang.ClassNotFoundException  com.jadex.qna.QNAProject.App
    

    所以很清楚错误的根源是什么。您正在尝试执行 Maven 无法找到其类文件的类的 main() 方法。正如this SO article 所讨论的,您可以尝试先显式编译,然后在生成类文件后执行:

    mvn -e compile exec:java
    mvn exec:java -Dexec.mainClass="com.jadex.qna.QNAProject.App"
    

    【讨论】:

    • 显式设置 JAVA_HOME 从控制台窗口指向 JDK 8:set JAVA_HOME=C:\Program Files\Java\jdk1.8.0_45 请注意,这只是控制台窗口的临时设置。
    【解决方案3】:

    我遇到了同样的问题,它是由端口冲突引起的。 我的 tomcat 服务器试图在端口 8080 上启动,但我已经绑定了它。 netstat -anto 将向您显示端口绑定 0.0.0.0:8080 或类似的,它的 PID 这将帮助您确定哪个进程已经在运行端口竞价,或者在您的 timcat 服务器中更改它,或者任何进程正在使用竞价。可能是由 IIS、SKype 或类似原因引起的。

    【讨论】:

      猜你喜欢
      • 2018-12-25
      • 2014-07-02
      • 2014-10-15
      • 2020-12-31
      • 2015-08-26
      • 1970-01-01
      • 2018-07-09
      • 2011-03-26
      • 2016-08-03
      相关资源
      最近更新 更多