前言
我们成功创建Spring Boot之后,pom.xml坐标文件中都会有如下一段引用:
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.4.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent>
对于这个parent的作用,我们是否完全理解? 有小伙伴说:不就是依赖的版本号定义在parent里边吗? 是的,没错,但是parent的作用可不仅仅这么简单哦! 那我们来看一看这个parent到底有什么作用。
基本功能
当我们创建一个Spring Boot 工程时,可以继承一个spring-boot-starter-parent,也可以不继承自它,我们先来看第一种情况。先来看 parent 的基本功能有哪些?
1. 定义了java编译版本为1.8;
2. 使用UTF-8格式编码;
3. 继承自spring-boot-dependencies,这个里边定义了依赖的版本,也正是因为继承了这个依赖,所以我们在写依赖时才不需要写版本号;
4. 执行打包操作的配置;
5. 自动化的资源过滤;
6. 自动化的插件配置;
7. 针对 application.properties 和 application.yml 的资源过滤,包括通过 profile 定义的不同环境的配置文件,例如 application-dev.properties 和 application-dev.yml。
请注意,由于application.properties和application.yml文件接收Spring样式占位符${ ... },因此Maven过滤更改为使用@ ... @占位符,当然开发者可以通过设置名为resource.delimiter的maven属性来覆盖@ .. @占位符
源码分析
当我们创建一个 Spring Boot 项目后,我们可以在本地 Maven 仓库中看到看到这个具体的 parent 文件,以 2.2.2 这个版本为例。打开这个文件,快速阅读文件源码,基本上就可以证实我们前面说的功能,如下图:
我们可以看到,它继承自 spring-boot-dependencies,这里保存了基本的依赖信息,另外我们也可以看到项目的编码格式,JDK的版本等信息,当然也有我们前面提到的数据过滤信息。
最后,我们再根据它的parent中指定的spring-boot-dependencies位置,来看看spring-boot-dependencies中的定义:
在这里,我们看到了版本的定义以及 dependencyManagement 节点,明白了为啥 Spring Boot 项目中部分依赖不需要写版本号了。
不用parent
但是并非所有的公司都需要这个parent,有时候,公司里边会有自己定义的parent,我们的Spring Boot项目要继承自公司内部的parent,这个时候该怎么办呢?
一个简单的办法就是我们在pom.xml文件中自行定义 dependencyManagement 节点,然后在里边定义好版本号,再接下来在引用依赖时也就不用写版本号了,像下面这样:
<dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>2.1.4.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
这样写之后,依赖的版本号问题虽然解决了,但是关于打包的插件、编译的 JDK 版本、文件的编码格式等等这些配置,在没有 parent 的时候,这些统统要自己去配置。
总结
好了,简单的文章到此结束,我们一起学习了 Spring Boot 项目中 parent 的作用。
感谢:http://www.javaboy.org/2019/0413/spring-boot-parent.html