Maven项目引用本地jar涉及scope和systemPath配置

Scope属性

XML 复制代码
<dependency>
    <groupId>com.hik</groupId>
    <artifactId>examples</artifactId>
    <version>1.0.0</version>
    <scope>system</scope>
    <systemPath>${project.basedir}/lib/examples.jar</systemPath>
</dependency>

先在pom文件中将依赖换成读取本地:<systemPath>

然后通过<scope>标签控制该jar包(依赖)的生存周期:

1. ‌**compile(默认作用域)**‌

  • 可用阶段‌:编译、测试、运行
  • 传递性‌:会传递给依赖项目
  • 打包行为‌:包含在项目构建的输出中(如 JAR/WAR 文件)
  • 典型场景‌:项目核心依赖(如 Spring Framework、日志库)
XML 复制代码
<dependency>
    <groupId>com.hik</groupId>
    <artifactId>examples</artifactId>
    <version>1.0.0</version>
    <scope>compile</scope> <!-- 可省略 -->
    <systemPath>${project.basedir}/lib/examples.jar</systemPath>
</dependency>

2. ‌provided

  • 可用阶段‌:编译、测试
  • 传递性‌:不会传递
  • 打包行为 ‌:‌不包含‌在构建输出中
  • 典型场景‌:容器提供的依赖(如 Servlet API、JavaEE API)
XML 复制代码
<dependency>
    <groupId>com.hik</groupId>
    <artifactId>examples</artifactId>
    <version>1.0.0</version>
    <scope>provided</scope>
    <systemPath>${project.basedir}/lib/examples.jar</systemPath>
</dependency>

3. ‌runtime

  • 可用阶段‌:测试、运行
  • 传递性‌:会传递
  • 打包行为‌:包含在构建输出中
  • 典型场景‌:运行时需要的驱动或实现(如 JDBC 驱动)
XML 复制代码
<dependency>
    <groupId>com.hik</groupId>
    <artifactId>examples</artifactId>
    <version>1.0.0</version>
    <scope>runtime</scope>
    <systemPath>${project.basedir}/lib/examples.jar</systemPath>
</dependency>

4. ‌test

  • 可用阶段‌:仅测试阶段
  • 传递性‌:不会传递
  • 打包行为‌:不包含在构建输出中
  • 典型场景‌:测试框架(JUnit、Mockito)
XML 复制代码
<dependency>
    <groupId>com.hik</groupId>
    <artifactId>examples</artifactId>
    <version>1.0.0</version>
    <scope>test</scope>
    <systemPath>${project.basedir}/lib/examples.jar</systemPath>
</dependency>

5. ‌**system(谨慎使用)**‌

  • 可用阶段‌:编译、测试(需手动配置运行)
  • 传递性‌:不会传递
  • 打包行为‌:默认不包含,需特殊配置
  • 典型场景‌:本地特殊 JAR(无法从仓库获取)
XML 复制代码
<dependency>
    <groupId>com.hik</groupId>
    <artifactId>examples</artifactId>
    <version>1.0.0</version>
    <scope>system</scope>
    <systemPath>${project.basedir}/lib/examples.jar</systemPath>
</dependency>

6. ‌**import(特殊作用域)**‌

  • 可用阶段‌:仅依赖管理
  • 传递性‌:不会传递
  • 打包行为‌:不包含
  • 典型场景‌:继承其他 POM 的依赖管理
XML 复制代码
<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>com.hik</groupId>
            <artifactId>examples</artifactId>
            <version>1.0.0</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

作用域对生命周期阶段的影响

作用域 编译 测试 运行 打包 传递依赖
compile ✔️ ✔️ ✔️ ✔️ ✔️
provided ✔️ ✔️
runtime ✔️ ✔️ ✔️ ✔️
test ✔️
system ✔️ ✔️ ⚠️* ️*

⚠️ system 作用域:运行和打包需要额外配置(如添加 <includeSystemScope>true</includeSystemScope>

最佳实践建议

  1. 避免使用 system 作用域 ‌:优先将本地 JAR 安装到仓库 (mvn install:install-file)
  2. 作用域最小化原则 ‌:使用能满足需求的最严格作用域(如能用 runtime 不用 compile
  3. provided 作用域用于容器依赖‌:防止与容器提供的库冲突
  4. test 作用域隔离测试依赖‌:减少最终包大小
  5. 使用 mvn dependency:tree 验证‌:检查依赖传递和冲突

打包扫描(jar包)

使用system引用时,<scope>,<systemPath>标签,这种方式在部署时才会出现的问题。部署到容器运行时,就会提示找不到类,因为该jar未被注入到项目lib中,需要在pom文件中增加打包扫描的配置。

需要配置 <build>

XML 复制代码
<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <includeSystemScope>true</includeSystemScope>
            </configuration>
        </plugin>
     </plugins>
     <finalName>${project.artifactId}</finalName>
</build>
相关推荐
deephub10 分钟前
向量相似性搜索详解:Flat Index、IVF 与 HNSW
人工智能·python·机器学习·embedding·向量检索
宸津-代码粉碎机20 分钟前
Spring Boot 4.0 实战技巧全解析
java·大数据·spring boot·后端·python
深度学习lover22 分钟前
<数据集>yolo微藻识别<目标检测>
人工智能·python·yolo·目标检测·计算机视觉·微藻识别
程序媛徐师姐31 分钟前
Python基于OpenCV的马赛克画的设计与实现【附源码、文档说明】
python·opencv·django·马赛克绘画·python马赛克绘画系统·马赛克画·python马赛克画
DeepModel31 分钟前
通俗易懂讲透随机梯度下降法(SGD)
人工智能·python·算法·机器学习
小锋java123438 分钟前
【技术专题】Matplotlib3 Python 数据可视化 - Matplotlib3 绘制条形图(Bar)
python
zhangzeyuaaa42 分钟前
Python推导式(Comprehensions)
开发语言·python
卷心菜狗44 分钟前
Python进阶基础--面向对象编程(OOP)
开发语言·python
superior tigre1 小时前
某为25.9.28 Yolo检测器中的anchor聚类(python实现)
python·yolo·聚类
这个人懒得名字都没写1 小时前
PyCharm图像查看器插件PixelLens
ide·python·pycharm