${project.basedir}延申出来的Maven内置的一些常用属性

如:${project.basedir} 是 Maven 的内置属性,可以被 pom.xml 直接识别。它表示当前项目的根目录(即包含 pom.xml 文件的目录)。

Maven 内置的一些常用属性:

  1. 项目相关
xml 复制代码
${project.basedir}        <!-- 项目根目录,即包含pom.xml文件的目录 -->
${project.build.directory} <!-- 构建目录,默认为 target -->
${project.version}        <!-- 项目版本 -->
${project.groupId}        <!-- 项目的groupId -->
${project.artifactId}     <!-- 项目的artifactId -->
  1. 实际使用示例
xml 复制代码
<dependency>
    <groupId>com.iflytek</groupId>
    <artifactId>scylla</artifactId>
    <version>1.0.0</version>
    <scope>system</scope>
    <systemPath>${project.basedir}/src/main/resources/lib/scylla.jar</systemPath>
</dependency>
  1. 也可以定义自己的属性
xml 复制代码
<properties>
    <lib.dir>${project.basedir}/src/main/resources/lib</lib.dir>
</properties>

<dependencies>
    <dependency>
        <groupId>com.iflytek</groupId>
        <artifactId>scylla</artifactId>
        <version>1.0.0</version>
        <scope>system</scope>
        <systemPath>${lib.dir}/scylla.jar</systemPath>
    </dependency>
</dependencies>
  1. 验证属性值
    你可以使用 Maven 命令来查看这些属性的实际值:
bash 复制代码
mvn help:evaluate -Dexpression=project.basedir -q -DforceStdout
  1. 常见的目录结构

    ${project.basedir}/
    ├── pom.xml
    └── src/
    └── main/
    ├── java/
    └── resources/
    └── lib/
    ├── scylla.jar
    └── mt_scylla.dll

所以,使用 ${project.basedir} 是完全可以的,而且是 Maven 推荐的做法,因为:

  1. 它是 Maven 标准属性,所有 Maven 项目都支持
  2. 它提供了项目路径的可移植性
  3. 不需要硬编码绝对路径
  4. 在不同操作系统上都能正常工作
相关推荐
麦兜*11 分钟前
Spring Boot 整合量子密钥分发(QKD)实验方案
java·jvm·spring boot·后端·spring·spring cloud·maven
码破苍穹ovo1 小时前
堆----1.数组中的第K个最大元素
java·数据结构·算法·排序算法
2301_793086871 小时前
JVM 01 运行区域
java·开发语言
崎岖Qiu1 小时前
【JVM篇13】:兼顾吞吐量和低停顿的G1垃圾回收器
java·jvm·后端·面试
久念祈2 小时前
C++ - 仿 RabbitMQ 实现消息队列--服务端核心模块实现(五)
java·rabbitmq·java-rabbitmq
超级晒盐人4 小时前
用落霞归雁的思维框架推导少林寺用什么数据库?
java·python·系统架构·学习方法·教育电商
岁忧4 小时前
(LeetCode 面试经典 150 题) 138. 随机链表的复制 (哈希表)
java·c++·leetcode·链表·面试·go
鹦鹉0074 小时前
IO流中的字节流
java·开发语言·后端
你我约定有三5 小时前
分布式微服务--Nacos作为配置中心(二)
java·分布式·spring cloud·微服务·架构·wpf·负载均衡
qq_165706075 小时前
java实现运行SQL脚本完成数据迁移
java·sql