【踩坑专栏】代码重构,项目分层:maven reload失败及依赖自身的问题

首先说一下背景,是一个单体的项目,我将它重构为分层的项目,将对外需要的参数和接口单独抽成一层api,打包对外提供出去。父pom用来管理依赖jar包和版本,子pom打包成jar。问题就在这里出现:

1,父依赖打包类型必须是pom

首先第一个问题,maven reload失败,看报错说是父pom必须是Pom类型,而我错误的将之设置为jar。

这里解释一下,父pom既然是用来管理jar包,那么其类型必须为pom类型[1],只有Pom类型的packaging的pom文件才能提供依赖管理的功能。

2,忘记添加dependencymanagement标签

父pom的打包类型改好以后,随之而来的是另一个问题,我在reload的时候发现报错,说api依赖自身。我感觉很奇怪,看api的pom里没有任何依赖,哪里来的依赖呢。想到这里,又发现了另一件奇怪的事,我在api里没有添加任何依赖,api里的lombok,rest注解等为什么没有报错呢?

想到这里,我赶紧去父pom里看了下,果然,是父pom直接用<dependencies>标签,外层没有<dependendymanagement>这个标签。

需要说明的是,打了<dependencies>标签的例如名为a的project或者module,凡是依赖或是继承了它的例如名为b的包,在b项目中无需声明即可将a中的依赖全部集成;而<dependendymanagement>则需要声明<groupId><artifactId>才能继承(无需<version>标签,版本由<dependendymanagement>管理)。

由于我忘记加了<dependendymanagement>,本应在<dependendymanagement>中管理的<api>,被api自身集成了,因此出现了引用自身的错误。添加<dependendymanagement>后,报错消失,同时api里的依赖消失,此后添加api需要的依赖重新reload即可。

最后,需要说的是,在多层module的project中,父pom起到的作用仅仅是提供依赖和版本的管理,包括自身的子module和第三方依赖,因此打包类型为pom,需要<dependendymanagement>标签
子module,则是具体工作的模块,因此类型需要为jar或者war(我一般用jar),不需要<dependendymanagement>标签,而需要用<dependencies>标签将父pom中的依赖显示的有选择的继承
有的时候工作忙的昏了头,早上清醒的时候一看,问题非常明显,但是有时候就看不出来QAQ

参考文章
[1],Maven的三种项目打包方式——pom,jar,war的区别

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值