记录一次pom.xml依赖顺序产生的错误

简介

有次想重构项目的依赖结构,将依赖的版本控制放到父工程的 pom.xml 中,公共依赖的引入放入到 common-api 模块中,各服务模块独有的依赖就放到该模块里。

没想到一路复制粘贴,搞出很多问题。如下,是某服务模块的依赖,引入了 common-api,和一个本地加载的 jar 包。

xml 复制代码
<dependencies>
    <dependency>
        <groupId>org.apache.james</groupId>
        <artifactId>apache-mime4j-core</artifactId>
        <scope>system</scope>
        <systemPath>../lib/本地Jar</systemPath>
    </dependency>
    <dependency>
        <groupId>com.hezy</groupId>
        <artifactId>common-api</artifactId>
        <version>1.0</version>
    </dependency>
</dependencies>

为了显眼(实则强迫症),把 common-api 挪到了第一个,如下。

xml 复制代码
<dependencies>
    <dependency>
        <groupId>com.hezy</groupId>
        <artifactId>common-api</artifactId>
        <version>1.0</version>
    </dependency>
    <dependency>
        <groupId>org.apache.james</groupId>
        <artifactId>apache-mime4j-core</artifactId>
        <scope>system</scope>
        <systemPath>../lib/本地Jar</systemPath>
    </dependency>
</dependencies>

结果报错了,为什么呢?

因为本地引入的这个依赖(jar 包),是基于 Maven 仓库中的公开 Jar 二次开发的,里面的包结构、类名称都和那个 Jar 高度相似,代码里优先使用了原来的那个 Jar,那个 Jar 的代码与我们业务代码不适配,所以报了编译错误。而原来那个 Jar 的依赖引入就是放到了 common-api 中,也就是说依赖在包名、类名相同的情况下,优先使用先定义的------谁在上面用谁的。

解决

解决很简单,方法一,停止手贱行为,不挪动顺序。方法二,在 common-api 中排除依赖,如下。

xml 复制代码
<dependencies>
    <dependency>
        <groupId>com.hezy</groupId>
        <artifactId>common-api</artifactId>
        <version>1.0</version>
        <exclusions>
        	<exclusion>
                <groupId>org.apache.james</groupId>
                <artifactId>apache-mime4j-core</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.apache.james</groupId>
        <artifactId>apache-mime4j-core</artifactId>
        <scope>system</scope>
        <systemPath>../lib/本地Jar</systemPath>
    </dependency>
</dependencies>
相关推荐
神奇小汤圆11 小时前
面试官:MySQL 为什么要是使用 MVCC?原理是什么?
后端
像我这样帅的人丶你还11 小时前
Java 后端详解(五):Redis 缓存
java·后端·全栈
玉宇夕落12 小时前
别再死磕 Prompt 了!上下文工程 (Context Engineering) 的简单学习
后端
用户342323237631712 小时前
定时器与 PWM 输出详解
后端
Jason_chen13 小时前
Linux 6.2 CAN/CANFD机制详解
后端
Apifox14 小时前
Apifox 6 月更新|Apifox CLI 全面升级、导入导出优化、OAuth 2.0 支持自动刷新令牌
前端·后端·测试
悟空瞎说14 小时前
NestJS 接口设计避坑:摒弃万能用户更新接口,落地单一职责与最小权限原则
后端·nestjs
smallyoung14 小时前
Spring AI 2.0 VectorStore实战:从原理到RAG落地
人工智能·后端
jiayou6414 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
青丘14 小时前
Spring AI整合Milvus向量数据库实战
后端