[开发工具]Maven 构建时报错:

一、问题描述

在项目的一个模块的根目录下,通过命令行执行 Maven 编译指令mvn complie出现构建失败,终端报错BUILD FAILURE :

Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile(default-compile) on project maven-javaee-build-05: Fatal error compiling: ЧĿ귢а: 17 -> [Help 1]

而使用 IDEA 的可视化界面就一切正常:

二、解决过程

1.官方文档

以后只用IDEA的可视化界面也就行了。但按理来说,这只是同一套构建指令的两种操作方式,不应当出现区别。出于好奇,我进入了终端报错 INFO 给出的帮助文档(MojoExecutionException - Apache Maven - Apache Software Foundation)。

该报错和Maven 本体无关,而是由于某个插件异常引起的。可以在 Plugin 列表(Apache Maven Compiler Plugin -- Plugin Documentation)可找到compiler插件的详细说明。

2. 命令行 --help 帮助

此外,可以在终端中输入用mvn compile -h查看参数用法。

3.检查 Java 版本

我的项目所用 JDK 是corretto-17.0.9

shell 复制代码
$ java -version #调用系统环境变量
java version "17.0.9" 2023-10-17 LTS
Java(TM) SE Runtime Environment (build 17.0.9+11-LTS-201)
Java HotSpot(TM) 64-Bit Server VM (build 17.0.9+11-LTS-201, mixed mode, sharing)

在maven的 setting.xml下已经添加了 profile

xml 复制代码
<profile>  
      <id>jdk-17</id>  
 
      <activation>  
        <activeByDefault>true</activeByDefault>  
        <jdk>17</jdk>  
      </activation>  
 
      <properties>  
        <maven.compiler.source>17</maven.compiler.source>  
        <maven.compiler.target>17</maven.compiler.target>  
        <maven.compiler.compilerVersion>17</maven.compiler.compilerVersion>  
      </properties>  
    </profile>

问题在于,本地机器上的用户环境变量JAVA_HOME仍是之前使用的Java 1.8,而 Maven 默认调用的就是这个用户环境变量。

三、解决方案

将用户环境变量 JAVA_HOME 值改为项目所用的 JDK 的目录。 问题解决:

相关推荐
前端付豪35 分钟前
Memory V1:让 AI 记住你的关键信息
前端·后端·llm
编码忘我1 小时前
RokcetMq的顺序消费、防丢失、去重
后端
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 基于SpringBoot+Vue的百货商品进出货平台为例,包含答辩的问题和答案
java·spring boot·后端
码路飞1 小时前
Claude Code 大规模封号,我花了一晚上才搞明白:setup token 和 API key 根本不是一回事
后端·claude
Cache技术分享1 小时前
359. Java IO API - 路径比较与处理
前端·后端
Leo8991 小时前
go从零单排之defer源码
后端
Java水解1 小时前
SQL 核心概念:JOIN 和 UNION 到底有什么区别?
后端·sql
夜空下的星1 小时前
springboot实现Minio大文件分片下载
java·spring boot·后端
lizhongxuan1 小时前
Claude Mem:为什么长上下文不等于好记忆
后端
y = xⁿ1 小时前
重生之我创作出了小红书:对象存储模块,用户资料模块
后端·mysql·intellij-idea