SpringCloud-Spring Boot Starter使用測試及問題小結

Spring Boot Starter是什麼?

Spring Boot Starter 是在 SpringBoot 組件中被提出來的一種概念、簡化瞭很多煩瑣的配置、通過引入各種 Spring Boot Starter 包可以快速搭建出一個項目的腳手架。

比如我們經常用的一些:

spring-boot-starter-web:

spring-boot-starter-data-redis:

spring-boot-starter-data-mongodb:

spring-boot-starter-data-jpa:

spring-boot-starter-activemq:

總體來說就是 starter 是一種對依賴的合成。

以前傳統的做法

在沒有 starter 之前,傳統的SSM項目、假如我想要在 Spring 中使用 jpa,可能需要做以下操作:

首先在 Maven 中引入使用的數據庫的依賴>>然後引入 jpa 的依賴>>在xml中配置一些屬性信息>>調試調用直到可以正常運行。

上面這樣的操作會有一些問題、比如:

如果過程比較繁瑣,這樣一步步操作會增加出錯的可能性。

在配置的時候也會劃掉大量的時間、對於新手和小白不太友好。

使用 Spring Boot Starter 之後

starter 的主要目的就是為瞭解決上面的這些問題

starter 的理念:

starter 會把所有用到的依賴都給包含進來,避免瞭開發者自己去引入依賴所帶來的麻煩。需要註意的是不同的 starter 是為瞭解決不同的依賴,所以它們內部的實現可能會有很大的差異,例如 jpa 的 starter 和 Redis 的 starter 可能實現就不一樣,這是因為 starter 的本質在於 synthesize,這是一層在邏輯層面的抽象,也許這種理念有點類似於 Docker,因為它們都是在做一個 “包裝” 的操作,如果你知道 Docker 是為瞭解決什麼問題的,也許你可以用 Docker 和 starter 做一個類比。

starter 的實現:

雖然不同的 starter 實現起來各有差異,但是他們基本上都會使用到兩個相同的內容:ConfigurationProperties 和 AutoConfiguration。因為 Spring Boot 堅信 “約定大於配置” 這一理念,所以我們使用 ConfigurationProperties 來保存我們的配置,並且這些配置都可以有一個默認值,即在我們沒有主動覆寫原始配置的情況下,默認值就會生效,這在很多情況下是非常有用的。除此之外,starter 的 ConfigurationProperties 還使得所有的配置屬性被聚集到一個文件中(一般在 resources 目錄下的 application.properties),這樣我們就告別瞭 Spring 項目中 XML 地獄。

上面的 starter 依賴的 jar 和我們自己手動配置的時候依賴的 jar 並沒有什麼不同,所以我們可以認為 starter 其實是把這一些繁瑣的配置操作交給瞭自己,而把簡單交給瞭用戶。除瞭幫助用戶去除瞭繁瑣的構建操作,在 “約定大於配置” 的理念下,ConfigurationProperties 還幫助用戶減少瞭無謂的配置操作。並且因為application.properties文件的存在,即使需要自定義配置,所有的配置也隻需要在一個文件中進行,使用起來非常方便。采用的starter都上面都給大傢列出來瞭。

創建Spring Boot Starter步驟

創建starter 項目

創建ConfigurationProperties 用來保存配置信息

創建AutoConfiguration,引用定義好的配置信息

在 AutoConfiguration 實現所有 starter 應該完成的操作,並且把這個類加入 spring.factories 配置文件中進行聲明

打包項在 SpringBoot 項目中引入該項目依賴,然後就可以使用該 starter 瞭

具體操作步驟:

在idea新建一個starter項目、直接執行下一步即可生成項目。

在xml中加入如下配置文件:

<?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>
    <artifactId>http-starter</artifactId>
    <version>0.0.1-SNAPSHOT</version>
 
    <!-- 自定義starter都應該繼承自該依賴 -->
    <!-- 如果自定義starter本身需要繼承其它的依賴,可以參考 https://stackoverflow.com/a/21318359 解決 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starters</artifactId>
        <version>1.5.2.RELEASE</version>
    </parent>
 
    <dependencies>
        <!-- 自定義starter依賴此jar包 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <!-- lombok用於自動生成get、set方法 -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.10</version>
        </dependency>
    </dependencies>
 
</project>

創建 proterties 類來保存配置信息

@ConfigurationProperties(prefix = "http") 
@Getter
public class HttpProperties {
 
    // 如果配置文件中配置瞭http.url屬性,則該默認屬性會被覆蓋
    private String url = "https://blog.csdn.net/weixin_39709134?type=blog";
 
}

創建業務類:

@Setter
@Getter
public class HttpClient {
 
    private String url;
 
    // 根據url獲取網頁數據
    public String getHtml() {
        try {
            URL url = new URL(this.url);
            URLConnection urlConnection = url.openConnection();
            BufferedReader br = new BufferedReader(new InputStreamReader(urlConnection.getInputStream(), "utf-8"));
            String line = null;
            StringBuilder sb = new StringBuilder();
            while ((line = br.readLine()) != null) {
                sb.append(line).append("\n");
            }
            return sb.toString();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return "error";
    }
 
}

這個業務類包含瞭url屬性和一個getHtml方法,用於獲取一個網頁HTML 數據

創建 AutoConfiguration

@Configuration
@EnableConfigurationProperties(HttpProperties.class)
public class HttpAutoConfiguration {
 
    @Resource
    private HttpProperties properties; // 使用配置
 
    // 在Spring上下文中創建一個對象
    @Bean
    @ConditionalOnMissingBean
    public HttpClient init() {
        HttpClient client = new HttpClient();
 
        String url = properties.getUrl();
        client.setUrl(url);
        return client;
    }
 
}

在上面的 AutoConfiguration 中我們實現瞭自己要求:在 Spring 的上下文中創建瞭一個 HttpClient 類的 bean,並且我們把 properties 中的一個參數賦給瞭該 bean。

最後,我們在resources文件夾下新建目錄META-INF,在目錄中新建spring.factories文件,並且在spring.factories中配置 AutoConfiguration:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.nosuchfield.httpstarter.HttpAutoConfiguration

最後使用 Maven 打包該項目。之後創建一個 SpringBoot 項目,在項目中添加我們之前打包的 starter 作為依賴,然後使用 SringBoot 來運行我們的 starter

測試如下:

@Component
public class RunIt {
 
    @Resource
    private HttpClient httpClient;
 
    public void hello() {
        System.out.println(httpClient.getHtml());
    }
 
}

之後可以在 application.properties中修改配置來進行測試證明 properties 中的數據確實被覆蓋

到此這篇關於SpringCloud-SpringBootStarter使用測試的文章就介紹到這瞭,更多相關SpringCloudSpringBootStarter使用內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: