背景:本项目使用JDK1.8html
编译maven工程的时候出现以下错误:java
Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1apache
pom中以下配置maven插件,配置中声明使用JDK1.8:maven
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.1</version> <configuration> <verbose>true</verbose> <fork>true</fork> <executable>${JAVA8_HOME}/bin/javac</executable> </configuration> </plugin>
这里的${JAVA8_HOME}这个变量是在settings.xml中配置的,以下:ide
<profile> <id>custom-compiler</id> <properties> <JAVA8_HOME>C:\Program Files (x86)\Java\jdk1.8.0_73</JAVA8_HOME> </properties> </profile>
固然这里应该须要激活,因此settings.xml文件还应该有以下配置:idea
<activeProfiles> <activeProfile>custom-compiler</activeProfile> </activeProfiles>
从pom文件中CTRL点击变量JAVA8_HOME能跳到settings.xml中找到它的定义处,按理来讲应该是能找到这个变量,出现上述问题并非由于找不到这个变量。我将pom文件中的JAVA8_HOME这个变量直接用实际的路径替换,即替换为spa
C:\Program Files (x86)\Java\jdk1.8.0_73\bin\javac 插件
发现编译经过,这就奇怪了。code
揭晓缘由:xml
maven实际上是有一个默认的仓库.m2仓库和默认的settings.xml配置文件,咱们在这个默认的settings.xml文件中也添加了一个JAVA8_HOME的变量后,编译就经过了,这就说明,maven编译的时候找的不是我在idea中配置的我自定义的settings.xml,而是先找的它默认的那个。由于里面没有,因此以前找不到JAVA8_HOME,致使编译失败、
总结:maven编译的时候应该是先找的默认的settings.xml,若是找不到,才会去找我在idea的settings选项下配置的“User settings file”中配置的settings.xml文件。
解决办法:删掉maven默认的去找的那个settings.xml文件,这样自定义的文件就会生效了
原文:https://www.cnblogs.com/telwanggs/p/7016570.html