• 【踩坑专栏】代码重构,项目分层: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直接用标签,外层没有这个标签。

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

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

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

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

  • 相关阅读:
    Mac Pro 突然不能双击打开文件夹
    [学习记录] SpringBoot 17. 数据访问 Mybatis
    配置ftp及java链接上传文件到ftp
    CTFHub | Cookie注入
    深度学习基础:超分辨率网络整理之EDVR网络
    数据库的基本概念和常见的数据库软件介绍
    使用 Dumpling 备份 TiDB 集群数据到兼容 S3 的存储
    Java算法-力扣leetcode-125. 验证回文串
    聊聊wireshark的进阶使用功能 | 京东云技术团队
    启动Hbase出现报错
  • 原文地址:https://blog.csdn.net/gengzhihao10/article/details/127843350