在先前的helloworld 範例中,已經初步體會到springboot 自動匯入依賴、完成設定的爽快了。
那麼,springboot 是如何實現的呢?
先看下上一篇內容範例中的pom.xml:
<!--导入父工程--> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.4.RELEASE</version> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>
這裡新增了一個父項目,另外只導入了一個依賴spring-boot-starter-web,最後我們所有相關的套件就進來了。
在整個過程中,無需關心導包問題。
每一個 springboot 工程都有一個父項目,一般都是用來做依賴管理的。
父項目中可能會申明很多的依賴,那麼子項目只要繼承了父項目,後續在添加依賴的時候就不需要添加版本號了。
以上述為例,父專案使用的是2.3.4.RELEASE的 springboot 版本,所以下面新增的依賴,就無需再寫版本號。
(1)父專案如何管理版本
可以按住ctrl,然後點選這個父專案進入一探究竟。
進來後發現他也有一個父專案spring-boot-dependencies。
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>2.3.4.RELEASE</version> </parent>
繼續進入到spring-boot-dependencies,在下面可以看到一個properties標籤:
這裡幾乎聲明了我們在開發中可能會用到的jar 包的版本。
繼續往下可以看到具體的依賴管理dependencyManagement,這裡引用的就是properties裡申明的版本。
舉個例子:
左邊我看到有個套件是logback,那麼就在裡面搜尋下,發現這裡定義好的版本就是1.2.3。
所以說,父專案的主要功能就是依賴管理,幾乎宣告了開發中常用的依賴的版本號碼。
(2)使用指定的版本
如果不要使用自動仲裁出的版本,而使用指定版本也是可以的。
例如 mysql 版本,自動仲裁的結果是8.0.21,但我只想用5.1.43的版本。
新增一個properties標籤,在裡面申明版本即可。
<properties> <mysql.version>5.1.43</mysql.version> </properties>
再看下導入的依賴,就已經變成指定的版本了。
再來看下最開始導入的一個依賴spring-boot-starter-web:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
後續會見到更多的以spring-boot-starter命名的啟動器。在官方文件裡也有詳細的說明
什麼是 starter?
starter 一組需要依賴的集合描述,也就是通常我們只需要引入一個 starter,那麼對應的整個開發場景就會引入了。
例如想開始使用 Spring 和 JPA 進行資料庫訪問,那麼就在專案中引入spring-boot-starter-data-jpa依賴項。
另外,注意這裡spring-boot-starter-*開頭的是官方的啟動器命名方式。
這麼說還有非官方的?是的,如果你覺得官方給你的 starter 場景還是無法滿足你的使用需要,那麼你可以自訂 starter。
但是官方推薦自訂的命名方式使用thirdpartyproject-spring-boot-starter。
至於為什麼只導入一個 starter 就可以導入整個場景的依賴,其實還是跟上面父專案一樣,maven 的依賴特性。
進入到spring-boot-starter-web,往下翻,就可以看到開發 web 場景所用到的依賴了。
所以,以後需要開發哪個場景,只要參考官方文件匯入對應的啟動器即可。
這裡再回顧一下之前的helloworld 專案中,springboot 自動配置好了哪些東西:
自動配好tomcat
自動配好springMVC
#自動配好web 常見功能,例如:字元編碼問題
默认的包结构:主程序所在包以及下面所有子包里的组件都会被默认扫描
各种配置拥有默认值
按需加载所有自动配置项
......
不管自动配置好什么,步骤都是:先引入、再配置。
比如 tomcat,那么前提是先引入了 tomcat 依赖,这就由上面第一部分内容所讲的依赖管理完成,在引入了 web starter 后,自动引入场景。
自动引入了场景,也就引入了这个场景下所用到的各种 jar 包,接下来就是要配置这些内容,比如 tomcat、springMVC 等等。
拿 springMVC 举例,在之前要使用 springMVC,肯定要配置DispatcherServlet,帮我们拦截所有请求。
<servlet> <servlet-name>springMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springMVC.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet>
现在看下之前的 helloworld 应用中,springboot 是在哪里帮我们做好配置的。
先看主程序类:
// 标记这是一个 springboot应用,这个类是主程序类,所有启动的入口 @SpringBootApplication public class MainApplication { public static void main(String[] args) { SpringApplication.run(MainApplication.class, args); } }
可以创建个本地变量(alt+enter),可以看到这个是个ConfigurableApplicationContext类型。
@SpringBootApplication public class MainApplication { public static void main(String[] args) { ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args); } }
可以使用getBeanDefinitionNames()方法,查看里面包含了哪些容器,遍历打印出来。
@SpringBootApplication public class MainApplication { public static void main(String[] args) { // 返回IOC容器 final ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args); // 查看容器里的组件 final String[] beanDefinitionNames = run.getBeanDefinitionNames(); for (String name: beanDefinitionNames) { System.out.println(name); } } }
接下来启动应用,看下控制台输出。
在控制台输出里ctrl+F搜索下DispatcherServlet:
发现 IOC 容器中已经有了对应的组件。
主程序所在包以及下面所有子包里的组件都会被默认扫描,所以我们不需要配置开启组件扫描,也可以正常使用。
但是要注意这里的范围:
示例中就是com.pingguo.boot包下以及所有子包都可以自动扫描。
如果你就是要放到外面,还希望被扫描到,怎么办?
那么可以使用主程序类中@SpringBootApplication注解中的一个属性scanBasePackages,扩大包的范围即可:
@SpringBootApplication(scanBasePackages = "com.pingguo") public class MainApplication { public static void main(String[] args) { ... ...
比如 tomcat端口,在application.properties配置文件里使用 idea 输入的时候,就可以看到带有默认值8080:
点击进去可看到后面都是绑定了对应的 java 类。
配置文件的值最终会绑定在对应的类上,这个类会在容器中创建对象。
比如应用中只引入了spring-boot-starter-web,那么就只有web场景的自动配置才会开启。
springboot 中的所有自动配置,都在这里:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-autoconfigure</artifactId> <version>2.3.4.RELEASE</version> <scope>compile</scope> </dependency>
点击spring-boot-starter-web可以找到spring-boot-starter,再进入其中就可以看到spring-boot-autoconfigure。
以上是SpringBoot自動配置如何實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!