前言
我們成功創建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