【Maven】-- Maven Scope 详解

devtools/2025/2/27 14:00:08/

目录

Maven Scope 详解

1. 引言

2. Maven 依赖范围(Scope)分类

2.1 compile(默认范围)

2.2 provided

2.3 runtime

2.4 test

2.5 system

2.6 import(仅用于 dependencyManagement)

3. Scope 作用范围总结

4. 结论


Maven Scope 详解

1. 引言

Maven 是 Java 项目构建和依赖管理的标准工具。在使用 Maven 进行依赖管理时,scope(作用范围)是一个重要的概念。Maven scope 决定了依赖项在编译、测试、运行等不同阶段的可用性。

本文将详细介绍 Maven 中的各种 scope 及其适用场景。


2. Maven 依赖范围(Scope)分类

Maven 主要提供以下几种 scope

2.1 compile(默认范围)

特点:

  • 依赖项在编译测试运行阶段均可用。
  • 这是 Maven 依赖的默认范围,如果未指定 scope,则默认使用 compile

适用场景:

  • 适用于编译期必须使用的依赖,例如 javax.servlet-api(如果是 web 应用)。

示例:

<dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId><version>3.12.0</version><scope>compile</scope>
</dependency>

2.2 provided

特点:

  • 依赖项在编译测试阶段可用,但在运行时不可用。
  • 适用于那些在运行时由容器或 JDK 提供的依赖。

适用场景:

  • 适用于 Web 项目中的 javax.servlet-api,因为它在运行时由 Tomcat 或其他服务器提供。
  • 适用于使用 JDK 自带库(如 tools.jar)的情况。

示例:

<dependency><groupId>javax.servlet</groupId><artifactId>javax.servlet-api</artifactId><version>4.0.1</version><scope>provided</scope>
</dependency>

2.3 runtime

特点:

  • 依赖项在测试运行阶段可用,但在编译时不可用。
  • 适用于那些只在运行时才需要的依赖。

适用场景:

  • 适用于 JDBC 驱动,如 mysql-connector-java,因为编译时通常不需要它,但运行时必须可用。

示例:

<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.28</version><scope>runtime</scope>
</dependency>

2.4 test

特点:

  • 依赖项仅在测试阶段可用,不会参与编译和运行。
  • 适用于单元测试框架或测试相关工具。

适用场景:

  • 适用于 JUnit、Mockito 等测试框架。

示例:

<dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.13.2</version><scope>test</scope>
</dependency>

2.5 system

特点:

  • 类似于 provided,但依赖项必须通过 systemPath 指定本地路径
  • 这种方式不建议使用,因为它破坏了 Maven 的依赖管理机制。

适用场景:

  • 适用于那些无法通过远程仓库获取的依赖,如某些商业库。

示例:

<dependency><groupId>com.example</groupId><artifactId>custom-lib</artifactId><version>1.0</version><scope>system</scope><systemPath>${project.basedir}/libs/custom-lib.jar</systemPath>
</dependency>

注意system 依赖不会从 Maven 仓库解析,建议尽量避免使用。


2.6 import(仅用于 dependencyManagement)

特点:

  • 仅用于 dependencyManagement 中,允许引入 BOM(Bill of Materials)。
  • 这种方式用于管理多个依赖的版本,而不会真正引入依赖。

适用场景:

  • 适用于 Spring Boot 等项目中引入官方 BOM。

示例:

<dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>2.7.2</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>

3. Scope 作用范围总结

Scope编译(Compile)测试(Test)运行(Runtime)典型使用场景
compile(默认)普通依赖,如 Apache Commons
provided运行环境提供的库,如 javax.servlet-api
runtime运行时才需要的库,如 mysql-connector-java
test测试框架,如 JUnit
system本地 jar,如商业库(不推荐)
import仅用于 dependencyManagement

4. 结论

Maven scope 的选择对项目的构建和运行至关重要。合理使用 scope,可以优化项目的依赖管理,提高构建效率。

  • 如果不确定,默认使用 compile
  • 如果依赖运行时由外部提供(如 Web 容器),使用 provided
  • 如果依赖仅在运行时使用,使用 runtime
  • 如果依赖仅用于测试,使用 test
  • 避免使用 system,优先使用远程仓库
  • 使用 import 来管理 BOM,保持依赖版本一致

希望本文能帮助你更好地理解 Maven 依赖范围的用法!


http://www.ppmy.cn/devtools/163081.html

相关文章

系统架构设计:系统分析与设计需要掌握的基本理念

在软件工程中,系统分析与设计是构建高质量软件的关键步骤。它决定了软件系统的架构、功能、性能和可维护性。本文将详细介绍系统分析与设计的重要知识点,并结合相关代码示例,帮助你更好地理解和应用这些知识。 一、系统分析 系统分析是软件开发生命周期中的一个重要阶段,…

obj离线加载(vue+threejs)+apk方式浏览

demo需求&#xff1a;移动端&#xff0c;实现obj本地离线浏览 结合需求&#xff0c;利用&#xff08;vue2threejs173&#xff09;进行obj的加载&#xff0c;然后采用apk方式&#xff08;hbuilderX打包发布&#xff09;移动端浏览&#xff1b; https://github.com/bianbian886/…

RPC 框架项目剖析

RPC 框架项目剖析 说明 本文用于梳理一个 rpc项目的实现细节&#xff0c;此项目基于cpp语言 大概三千行左右&#xff0c;用于学习目的。 项目链接&#xff1a;rpc项目 项目底层类 1.抽象消息类 描述&#xff1a; 各种消息的基类 属性&#xff1a; 消息id&#xff0c;消息类型…

6.6.3 SQL数据查询(一)

文章目录 SELECT语句简单查询连接查询子查询聚集函数 SELECT语句 SELECT是用于查询的动词&#xff0c;基本格式为SELECT-FROM-WHERE&#xff0c;其中WHERE可选。SELECT对应投影运算&#xff0c;FROM对应笛卡尔积运算&#xff0c;WHERE对应选择运算。选择使用的条件表达式p可包含…

【2025全网最新最全】前端Vue3框架的搭建及工程目录详解

文章目录 安装软件Node.js搭建Vue工程创建Vue工程精简Vue项目文件 Vue工程目录的解读网页标题的设置设置全局样式路由配置 安装软件Node.js 下载地址&#xff1a;https://nodejs.org/zh-cn/ 安装完成后&#xff0c;打开cmd,查看环境是否准备好 node -v npm -vnpm使用之前一定…

Ubuntu22上安装MySQL8启动成功,远程无法连接

解决步骤: 1.首先验证网络是否通 ping Linux服务器ip 2.如果网络通&#xff0c;验证是否开放了访问 2.1在服务器上使用 sudo mysql -u root -p 并输入密码连接到mysql 2.2执行 SELECT User, Host FROM mysql.user; 查找一个Host列为’%的用户&#xff0c;这表示允许从任何主机连…

使用 frp 实现内网穿透:从零到一的完整指南

使用 frp 实现内网穿透&#xff1a;从零到一的完整指南 &#x1f381; DeepSeek满血版免费领啦&#xff01;字节跳动火山引擎官方&#xff0c;免费抵扣3625万tokens&#xff0c;畅享R1与V3模型&#xff01;参与入口&#xff1a;点击进入 为什么需要内网穿透&#xff1f; 在日常…

大连指令数据集的创建--数据收集与预处理_02

1.去哪儿爬虫 编程语言&#xff1a;Python爬虫框架&#xff1a;Selenium&#xff08;用于浏览器自动化&#xff09;解析库&#xff1a;BeautifulSoup&#xff08;用于解析HTML&#xff09; 2.爬虫策略 目标网站&#xff1a;去哪儿&#xff08;https://travel.qunar.com/trav…