Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.0:compile (default-compile

背景:本項目使用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

相關文章
相關標籤/搜索