springboot?自定義啟動(dòng)器的實(shí)現(xiàn)
創(chuàng)建自定義啟動(dòng)器
0、項(xiàng)目總覽
1、創(chuàng)建項(xiàng)目,引入依賴
創(chuàng)建項(xiàng)目 spring-boot-jdbc-starter,引入依賴,pom
文件如下:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.shwen</groupId> <artifactId>spring-boot-jdbc-starter</artifactId> <version>1.0-SNAPSHOT</version> <name>spring-boot-jdbc-starter</name> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.3.RELEASE</version> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.7</maven.compiler.source> <maven.compiler.target>1.7</maven.compiler.target> </properties> <dependencies> <!--引入spring‐boot‐starter;所有starter的基本配置--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!--自動(dòng)配置連接池--> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.12</version> </dependency> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <version>0.9.1.2</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> </dependencies> </project>
啟動(dòng)器支持多種數(shù)據(jù)源,例如:C3P0和Druid,根據(jù)配置的type
進(jìn)行選擇。此處我們引用兩個(gè)連接池依賴,一個(gè)是C3P0,一個(gè)是Druid。
2、創(chuàng)建屬性配置類
package com.shwen.properties; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; @Component @ConfigurationProperties(prefix = "spring.jdbc.datasource") public class DataSourceProperties { private String driverClassName; private String url; private String username; private String password; public String getDriverClassName() { return driverClassName; } public void setDriverClassName(String driverClassName) { this.driverClassName = driverClassName; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } @Override public String toString() { return "DataSourceProperties{" + "driverClassName='" + driverClassName + '\'' + ", url='" + url + '\'' + ", username='" + username + '\'' + ", password='" + password + '\'' + '}'; } }
屬性配置類注入 application.yml 文件中的配置信息。
3、創(chuàng)建自動(dòng)配置類
package com.shwen.autoconfig; import ... import javax.sql.DataSource; @SpringBootConfiguration @EnableConfigurationProperties(DataSourceProperties.class) public class DataSourceAutoConfiguration { @Autowired private DataSourceProperties dataSourceProperties ; @Bean @ConditionalOnProperty(value = "spring.jdbc.datasource.type",havingValue = "druid") public DataSource createDataSource(){ DruidDataSource dataSource = new DruidDataSource(); dataSource.setDriverClassName(dataSourceProperties.getDriverClassName()); dataSource.setUrl(dataSourceProperties.getUrl()); dataSource.setUsername(dataSourceProperties.getUsername()); dataSource.setPassword(dataSourceProperties.getPassword()); return dataSource; } @Bean @ConditionalOnProperty(value = "spring.jdbc.datasource.type",havingValue = "c3p0") public DataSource createC3P0DataSource() throws Exception{ ComboPooledDataSource dataSource = new ComboPooledDataSource(); dataSource.setDriverClass(dataSourceProperties.getDriverClassName()); dataSource.setJdbcUrl(dataSourceProperties.getUrl()); dataSource.setUser(dataSourceProperties.getUsername()); dataSource.setPassword(dataSourceProperties.getPassword()); return dataSource; } }
- 如果配置文件中配置了
spring.jdbc.datasource.type=c3p0
,使用 c3p0 數(shù)據(jù)源。 - 如果配置文件中配置了
spring.jdbc.datasource.type=druid
,使用 druid 數(shù)據(jù)源。
此處使用條件選擇實(shí)現(xiàn),@ConditionalOnProperty(value = "spring.jdbc.datasource.type",havingValue = "druid")
根據(jù)配置文件中的 type
值進(jìn)行條件選擇創(chuàng)建不同的 DataSource
。
4、創(chuàng)建自動(dòng)配置屬性文件
在resource
文件夾下面新建 META-INF/spring.factories
# Auto Configure org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.shwen.autoconfig.DataSourceAutoConfiguration
注意要執(zhí)行 install ,安裝項(xiàng)目。
使用自定義啟動(dòng)器
1、springboot_01 項(xiàng)目引入自定義啟動(dòng)器
pom
文件:
<dependency> <groupId>com.shwen</groupId> <artifactId>spring-boot-jdbc-starter</artifactId> <version>1.0-SNAPSHOT</version> </dependency>
2、配置連接池信息
application.yml
:
配置文件配置 type
指定需要?jiǎng)?chuàng)建的數(shù)據(jù)源,此處指定數(shù)據(jù)源為druid
,并且配置連接屬性信息。
3、注入屬性測(cè)試
@RestController public class HelloController { @Autowired private DataSource dataSource; @RequestMapping(path = "/hello2") public String sayHello2() throws SQLException { System.out.println(dataSource.getClass()); DruidDataSource dds = (DruidDataSource) dataSource; System.out.println(dds.getPassword()); return "hello spring boot"; } }
注入DataSource,查看連接池屬性。
訪問 http://127.0.0.1:8080/hello2
,打印結(jié)果:
小結(jié)
通過編寫自定義啟動(dòng)器,我們更加理解springboot自動(dòng)配置原理。springboot項(xiàng)目啟動(dòng)后,
- 會(huì)讀取所有依賴的 jar 包下面 META-INF/spring.factories 文件,而該文件配置了自動(dòng)配置類,將 spring.factories 中的配置類的全名稱獲取到,并且根據(jù)加載條件來加載項(xiàng)目所需要的類。
- 通過
反射
實(shí)例化標(biāo)注了@Configuration
的 IOC容器配置類,然后匯總并加載到 IOC 容器。當(dāng)收集到所有在 spring.factories 中指定的bean后,再通過@Import
注解將其導(dǎo)入進(jìn)容器。 @ConfigurationProperties
注解會(huì)讀取配置文件 application.yml 里面屬性,將讀到的值綁定到被注解類的屬性。然后,@EnableConfigurationProperties
將屬性配置類注入到 IOC 容器中,這樣當(dāng)項(xiàng)目需要配置信息的時(shí)候可以直接從容器中去取。- 至此,依賴的 jar 包中自動(dòng)配置類注入成功,項(xiàng)目可以直接通過
@Autowired
裝配使用。
到此這篇關(guān)于springboot 自定義啟動(dòng)器的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)springboot 自定義啟動(dòng)器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot中實(shí)現(xiàn)Redis緩存預(yù)熱
緩存預(yù)熱是一種在系統(tǒng)啟動(dòng)后,但在實(shí)際使用前將數(shù)據(jù)加載到緩存中的技術(shù),本文主要來和大家一起探討如何在Spring Boot應(yīng)用程序中實(shí)現(xiàn)Redis緩存預(yù)熱,以確保系統(tǒng)在處理請(qǐng)求前就已經(jīng)處于最佳狀態(tài),感興趣的可以了解下2023-11-11Java多線程讀寫鎖ReentrantReadWriteLock類詳解
本文詳細(xì)講解了Java多線程讀寫鎖ReentrantReadWriteLock類,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12SpringBoot整合ip2region實(shí)現(xiàn)使用ip監(jiān)控用戶訪問城市的詳細(xì)過程
這篇文章主要介紹了SpringBoot整合ip2region實(shí)現(xiàn)使用ip監(jiān)控用戶訪問城市,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07JAVA實(shí)現(xiàn)用戶抽獎(jiǎng)功能(附完整代碼)
這篇文章主要給大家介紹了關(guān)于JAVA實(shí)現(xiàn)用戶抽獎(jiǎng)功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11@PreAuthorize、@PostAuthorize、@PreFilter、@PostFilter注解的用法詳解
這篇文章主要介紹了@PreAuthorize、@PostAuthorize、@PreFilter、@PostFilter注解的用法詳解,通過在方法上添加@PreAuthorize注解,可以指定需要滿足的權(quán)限條件,只有滿足條件的用戶才能執(zhí)行該方法,需要的朋友可以參考下2023-10-10MyBatis-Plus集成Druid環(huán)境搭建的詳細(xì)教程
這篇文章主要介紹了MyBatis-Plus集成Druid環(huán)境搭建的詳細(xì)教程,需要的朋友可以參考下2020-08-08