执行javac失败:编译失败

时间:2013-06-06 07:50:34

标签: maven

相同的项目在两台不同的笔记本电脑上使用maven构建。在一个运行好的和一个显示错误。

状态:两个系统的配置相同。

C:\Users\admin>mvn -version
Apache Maven 2.2.1 (r801777; 2009-08-07 00:46:01+0530)
Java version: 1.6.0_43
Java home: C:\Installers\Java\jdk1.6.0_43\jre
Default locale: en_IN, platform encoding: Cp1252
OS name: "windows 7" version: "6.1" arch: "amd64" Family: "windows"

使用的命令: mvn clean install -DskipTests = true

错误:

[INFO] [compiler:compile {execution: default-compile}]
[INFO] Compiling 3 source files to C:\Users\admin\HeliosWorkspace\...\target\classes
[INFO] ------------------------------------------------------------------------
[ERROR] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Compilation failure
Failure executing javac,  but could not parse the error:
The system cannot find the path specified.

[INFO] ------------------------------------------------------------------------
[INFO] Trace
org.apache.maven.BuildFailureException: Compilation failure
Failure executing javac,  but could not parse the error:
The system cannot find the path specified.    

        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoals(DefaultLifecycleExecutor
.java:715)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoalWithLifecycle(DefaultLifec
ycleExecutor.java:556)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoal(DefaultLifecycleExecutor.
java:535)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoalAndHandleFailures(DefaultL
ifecycleExecutor.java:387)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeTaskSegments(DefaultLifecycleE
xecutor.java:348)
        at org.apache.maven.lifecycle.DefaultLifecycleExecutor.execute(DefaultLifecycleExecutor.java
:180)
        at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:328)
        at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:138)
        at org.apache.maven.cli.MavenCli.main(MavenCli.java:362)
        at org.apache.maven.cli.compat.CompatibleMain.main(CompatibleMain.java:60)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.codehaus.classworlds.Launcher.launchEnhanced(Launcher.java:315)
        at org.codehaus.classworlds.Launcher.launch(Launcher.java:255)
        at org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:430)
        at org.codehaus.classworlds.Launcher.main(Launcher.java:375)
Caused by: org.apache.maven.plugin.CompilationFailureException: Compilation failure
Failure executing javac,  but could not parse the error:
The system cannot find the path specified.

我甚至尝试删除所有内容,例如再次创建.m2文件夹。

5 个答案:

答案 0 :(得分:5)

我遇到了这个问题,并通过一些故障排除解决了这个问题。

当您尝试执行文件但输入无效路径时,这实际上是一条DOS错误消息。

C:\Users\me>c:\asdf\foo.exe
The system cannot find the path specified.

Maven正在尝试执行javac来编译代码但没有正确的路径。对于许多设置,您需要在pom.xml中检查编译器的路径。转到cmd提示符并将其复制并粘贴,并确保其有效路径。

对于使用settings.xml配置文件在不同JAVA_HOME上定义某些全局配置的设置,例如下面的示例,确保每个变量中的路径都正确,带有这些变量的配置文件是活动的(activeProfile标记可以确保这一点),并在pom.xml中正确引用

<!-- settings.xml -->
<profiles>
<profile>
  <id>compiler-versions</id> 
    <properties>
        <JAVA_1_5_HOME>C:/java/jdk1.5.0_16</JAVA_1_5_HOME>
        <JAVA_1_6_HOME>C:/java/jdk1.6.0_43</JAVA_1_6_HOME>
        <JAVA_1_7_HOME>C:/java/jdk1.7.0_55</JAVA_1_7_HOME>
  </properties>
</profile>
</profiles>


 <activeProfiles>
    <!-- make the profile active all the time -->
    <activeProfile>compiler-versions</activeProfile>
 </activeProfiles>

pom.xml片段:

<!-- pom.xml -->
<!-- ... -->
<build>
            <configuration>
                <verbose>false</verbose>
                <fork>true</fork>
                <executable>${JAVA_1_6_HOME}/bin/javac</executable>
                <compilerVersion>1.6</compilerVersion>
                <meminitial>256m</meminitial>
                <source>1.6</source>
                <target>1.6</target>
                <!--encoding>UTF-8</encoding-->
                <maxmem>512m</maxmem>
            </configuration>
</build>

答案 1 :(得分:2)

谢谢大家,现在正在努力:

mvn -X clean install -DskipTests=true

调试模式非常有用。

答案 2 :(得分:0)

检查您的POM文件并确保您拥有适用于MAVEN和Java的正确环境变量

答案 3 :(得分:0)

我有一个类似的问题,我发现settings.xml @ Maven_home / conf或C:\ Users \ .m2 \ settings.xml指向错误的JDK路径,纠正哪个确实解决了问题。上面打印的错误消息实际上是“执行javac失败”的位置,这意味着Maven没有找到JDK。

由于 Hithesh

答案 4 :(得分:0)

我知道这是一个古老的话题,但我认为这个答案将有助于未来的人们:

  

Java home:C:\ Installers \ Java \ jdk1.6.0_43 \ jre

您正在使用JRE而不是JDK。只需从您的java主页中删除“\ jre”