针对Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1的解决方案

针对Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1的解决方案背景 本项目使用 JDK1 8 编译 maven 工程的时候出现如下错误 Failedtoexec apache maven plugins maven compiler plugin 3 1pom 中如下配置 maven 插件 配置中声明使用 JDK1 8 org apache maven plugins maven compiler plugin 3

背景:本项目使用JDK1.8

编译maven工程的时候出现如下错误:

pom中如下配置maven插件,配置中声明使用JDK1.8:

 
   
   
     org.apache.maven.plugins 
    
   
     maven-compiler-plugin 
    
   
     3.1 
    
    
    
      true 
     
    
      true 
     
    
      ${JAVA8_HOME}/bin/javac 
     
    
  

这里的${JAVA8_HOME}这个变量是在settings.xml中配置的,如下:

 
   
   
     custom-compiler 
    
    
    
      C:\Program Files (x86)\Java\jdk1.8.0_73 
     
    
  

当然这里应该需要激活,所以settings.xml文件还应该有如下配置:

 
   
   
     custom-compiler 
    
  

从pom文件中CTRL点击变量JAVA8_HOME能跳到settings.xml中找到它的定义处,按理来说应该是能找到这个变量,出现上述问题并不是因为找不到这个变量。我将pom文件中的JAVA8_HOME这个变量直接用实际的路径替换,即替换为

C:\Program Files (x86)\Java\jdk1.8.0_73\bin\javac

发现编译通过,这就奇怪了。

揭晓原因:

maven其实是有一个默认的仓库.m2仓库和默认的settings.xml配置文件,我们在这个默认的settings.xml文件中也添加了一个JAVA8_HOME的变量后,编译就通过了,这就说明,maven编译的时候找的不是我在idea中配置的我自定义的settings.xml,而是先找的它默认的那个。因为里面没有,所以之前找不到JAVA8_HOME,导致编译失败、

总结:maven编译的时候应该是先找的默认的settings.xml,如果找不到,才会去找我在idea的settings选项下配置的“User settings file”中配置的settings.xml文件。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/224359.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午12:06
下一篇 2026年3月17日 下午12:07


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号