首先说一下背景,是一个单体的项目,我将它重构为分层的项目,将对外需要的参数和接口单独抽成一层api,打包对外提供出去。父pom用来管理依赖jar包和版本,子pom打包成jar。问题就在这里出现:
首先第一个问题,maven reload失败,看报错说是父pom必须是Pom类型,而我错误的将之设置为jar。
这里解释一下,父pom既然是用来管理jar包,那么其类型必须为pom类型[1],只有Pom类型的packaging的pom文件才能提供依赖管理的功能。
父pom的打包类型改好以后,随之而来的是另一个问题,我在reload的时候发现报错,说api依赖自身。我感觉很奇怪,看api的pom里没有任何依赖,哪里来的依赖呢。想到这里,又发现了另一件奇怪的事,我在api里没有添加任何依赖,api里的lombok,rest注解等为什么没有报错呢?
想到这里,我赶紧去父pom里看了下,果然,是父pom直接用标签,外层没有这个标签。
需要说明的是,打了标签的例如名为a的project或者module,凡是依赖或是继承了它的例如名为b的包,在b项目中无需声明即可将a中的依赖全部集成;而则需要声明和才能继承(无需标签,版本由管理)。
由于我忘记加了,本应在中管理的,被api自身集成了,因此出现了引用自身的错误。添加后,报错消失,同时api里的依赖消失,此后添加api需要的依赖重新reload即可。
最后,需要说的是,在多层module的project中,父pom起到的作用仅仅是提供依赖和版本的管理,包括自身的子module和第三方依赖,因此打包类型为pom,需要;
而子module,则是具体工作的模块,因此类型需要为jar或者war(我一般用jar),不需要。
有的时候工作忙的昏了头,早上清醒的时候一看,问题非常明显,但是有时候就看不出来QAQ
参考文章
[1],Maven的三种项目打包方式——pom,jar,war的区别