前两天同事遇到一个问题:

同一个工程,依赖私有库中的一个jar包,其他同事的项目都能成功下载,但只有他的项目无法正常下载依赖,最后虽然找到原因了,但还是在这里备注一下:

1、maven依赖管理

maven通过GAV坐标对项目依赖进行管理,如果有公司内部有私有库存在的话,依赖查找的顺序是这样的:本地仓库-->私有仓库-->中央仓库(这是没有配置mirror拦截的情况);如果在setting中配置了mirror,且mirrorOf配置为*,url指向私有库路径,则查找顺序是这样的本地仓库-->私有仓库(-->中央仓库),即:对中央仓库查找依赖的发起方不同

2、maven依赖路径

依赖路径指的是项目结构parent的继承顺序,一般情况下,项目的maven模块只会分成2级,即:

maven-project-parent(pom)

---maven-project-api(jar)

---maven-project-core(jar)

---maven-project-web(war)

当然也有多级的情况:

maven-project-parent(pom)

---maven-project-loan-parent(pom)

------maven-project-loan-api(jar)

------maven-project-loan-core(jar)

------maven-project-loan-web(war)

---maven-project-invest-parent(pom)

------maven-project-invest-api(jar)

------maven-project-invest-core(jar)

------maven-project-invest-web(war)

3、maven下载依赖包顺序

下载顺序就是根据依赖路径来进行下载的,比如上图中多级项目中的maven-project-invest-api项目如果依赖于如下项目中的dependency-project-api项目:

dependency-project-parent

---dependency-project-api

---dependency-project-core

---dependency-project-web

但此项目中只有api包才被deploy到maven私有库中,所以根据依赖下载顺序,项目首先回去下载dependency-project-api的父pom---dependency-project-parent,但私有库中没有,于是就会出现此私有库中有dependency-project-api.jar,但无法下载jar包的问题,

4、解决方案:

(1)如果有源代码的话,直接将dependency-project-parent代码clone到本地,然后install到本地仓库中解决依赖

(2)将dependency-project-parent重新deploy到私有库中