日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

如何手寫一個Spring Boot Starter

瀏覽:219日期:2023-07-20 14:43:52
何為 Starter ?

想必大家都使用過 SpringBoot,在 SpringBoot 項目中,使用最多的無非就是各種各樣的 Starter 了。那何為 Starter 呢?你可以理解為一個可拔插式的插件(組件)?;蛘呃斫鉃閳鼍皢悠?。

通過 Starter,能夠簡化以前繁雜的配置,無需過多的配置和依賴,它會幫你合并依賴,并且將其統一集成到一個 Starter 中,我們只需在 Maven 或 Gradle 中引入 Starter 依賴即可。SpringBoot 會自動掃描需要加載的信息并啟動相應的默認配置。例如,如果你想使用 jdbc 插件,你只需引入 spring-boot-starter-jdbc 即可;如果你想使用 mongodb,你只需引入 spring-boot-starter-data-mongodb 依賴即可。

SpringBoot 官方提供了大量日常企業應用研發各種場景的 spring-boot-starter 依賴模塊。這些依賴模塊都遵循著約定成俗的默認配置,并允許我們根據自身情況調整這些配置。

總而言之,Starter 提供了以下功能:

整合了模塊需要的所有依賴,統一集合到 Starter 中。 提供了默認配置,并允許我們調整這些默認配置。 提供了自動配置類對模塊內的 Bean 進行自動裝配,注入 Spring 容器中。 Starter 命名規則

Spring 官方定義的 Starter 通常命名遵循的格式為 spring-boot-starter-{name},例如 spring-boot-starter-data-mongodb。Spring 官方建議,非官方 Starter 命名應遵循 {name}-spring-boot-starter 的格式,例如,myjson-spring-boot-starter。

自定義一個 Starter

了解了 Starter 的含義以及應用場景后,我們可以嘗試手寫一個 Starter,加深對它的了解以及能在實際工作中,開發出自己的 Starter,提高我們的開發效率。

可能有人會問 Starter 能干嘛呢?其實在我們的日常開發工作中,總有一些獨立于業務系統之外的配置模塊,它是可以在不同項目中進行復用的。如果在每個項目中都編寫重復的模塊代碼,不僅浪費時間和人力,而且還和項目耦合。所以我們將這些可獨立于業務代碼之外的功能配置模塊封裝成一個 Starter,在需要用到此功能模塊的項目中,只需要在其 pom.xml 文件中引用依賴即可,SpringBoot 幫我們完成自動裝配,而且我們還可以在配置文件中調整 Starter 中默認的配置信息。

假設我們現在需要實現這樣一個功能:

根據用戶提供的 Java 對象,將其轉換為 JSON 形式,并且在 JSON 字符串中添加指定的前輟和后輟。 用戶可以動態改變前輟和后輟,即可在 yml 或 properties 配置文件中自定義。

舉個栗子,假如用戶輸入下面這個類的對象 person:

public class Person { private String name; private int age; private String address; public Person(String name, int age, String address) { super(); this.name = name; this.age = age; this.address = address; } // 省略get和set方法}

Person person = new Person('Mr.nobody', 18, '拉斯維加斯');

并假設用戶在 application.yml 配置文件中配置的前輟為 @,后輟為 %,則最終生成的字符串為:

@{'address':'拉斯維加斯','age':18,'name':'Mr.nobody'}%

首先新建一個 Maven 工程(當然也可以其他類型例如 Gradle 工程),在 pom.xml 文件中引入如下依賴。fastjson 依賴是我們業務用到將 Java 對象轉換為 JSON 字符串;spring-boot-configuration-processor 依賴是可選的,加入此依賴主要是打包時,自動生成配置元信息文件 META-INF/spring-configuration-metadata.json,并放入到 jar 中。方便使用者了解到一些配置元信息。

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd'><modelVersion>4.0.0</modelVersion><groupId>com.nobody</groupId><artifactId>myjson-spring-boot-starter</artifactId><version>0.0.1-SNAPSHOT</version><name>myjson-spring-boot-starter</name><description>Demo project for Spring Boot Starter</description><properties><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId><version>2.3.8.RELEASE</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><version>2.3.8.RELEASE</version><optional>true</optional></dependency><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.73</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-autoconfigure</artifactId><version>2.3.8.RELEASE</version></dependency></dependencies></project>

業務處理類,實現 Java 對象轉換為帶有指定前后綴的 JSON 字符串。

package com.nobody.myjson.service;import com.alibaba.fastjson.JSON;/** * @Description 業務處理類 * @Author Mr.nobody * @Date 2021/2/27 * @Version 1.0 */public class MyJsonService { // 前綴 private String prefixName; // 后綴 private String suffixName; /** * 將Java對象轉為帶有指定前后綴的JSON字符串 * * @param o 需要轉換的Java對象 * @return 轉換后的字符串 */ public String objectToMyJson(Object o) { return prefixName + JSON.toJSONString(o) + suffixName; } public String getPrefixName() { return prefixName; } public void setPrefixName(String prefixName) { this.prefixName = prefixName; } public String getSuffixName() { return suffixName; } public void setSuffixName(String suffixName) { this.suffixName = suffixName; }}配置類,定義需要的配置信息和默認配置項,并指明關聯配置文件的配置項前綴。它可以把相同前綴的配置信息通過配置項名稱映射成實體類的屬性中。package com.nobody.myjson.config;import org.springframework.boot.context.properties.ConfigurationProperties;/** * @Description 配置類(類名一般為模塊名+Properties) nobody.json為Starter使用者通過yml配置文件動態修改屬性值的變量名前綴 * @Author Mr.nobody * @Date 2021/2/27 * @Version 1.0 */@ConfigurationProperties(prefix = 'nobody.json')public class MyJsonProperties { // Starter使用者沒在配置文件中配置prefixName屬性的值時的默認值 public static final String DEFAULT_PREFIX_NAME = '@'; // Starter使用者沒在配置文件中配置suffixName屬性的值時的默認值 public static final String DEFAULT_SUFFIX_NAME = '@'; private String prefixName = DEFAULT_PREFIX_NAME; private String suffixName = DEFAULT_SUFFIX_NAME; public String getPrefixName() { return prefixName; } public void setPrefixName(String prefixName) { this.prefixName = prefixName; } public String getSuffixName() { return suffixName; } public void setSuffixName(String suffixName) { this.suffixName = suffixName; }}

自動裝配類,使用 @Configuration 和 @Bean 來進行自動裝配,注入 Spring 容器中。

package com.nobody.myjson.config;import com.nobody.myjson.service.MyJsonService;import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;import org.springframework.boot.context.properties.EnableConfigurationProperties;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;/** * @Description 自動裝配類 * @Author Mr.nobody * @Date 2021/2/27 * @Version 1.0 */@Configuration // 標識此類是配置類@ConditionalOnClass(MyJsonService.class) // 表示只有指定的class在classpath上時才能被注冊@EnableConfigurationProperties(MyJsonProperties.class) // 激活@ConfigurationPropertiespublic class MyJsonConfiguration { private MyJsonProperties myJsonProperties; // 自動注入配置類 public MyJsonConfiguration(MyJsonProperties myJsonProperties) { this.myJsonProperties = myJsonProperties; } // 創建MyJsonService對象,注入到Spring容器中 @Bean @ConditionalOnMissingBean(MyJsonService.class) // 當容器沒有此bean時,才注冊 public MyJsonService myJsonService() { MyJsonService myJsonService = new MyJsonService(); myJsonService.setPrefixName(myJsonProperties.getPrefixName()); myJsonService.setSuffixName(myJsonProperties.getSuffixName()); return myJsonService; }}

在 src/main/resources/META-INF目錄下新建 spring.factories 文件,輸入以下內容:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.nobody.myjson.config.MyJsonConfiguration

SpringBoot 項目啟動時,類加載器會從 META-INF / spring.factories 加載給定類型的工廠實現的完全限定類名。也就是說類加載器得到工程中所有 jar 包中的 META-INF/spring.factories 文件資源,從而得到了一些包括自動配置相關的類的集合,然后將它們實例化,放入 Spring 容器中。

最終項目結構如下:

如何手寫一個Spring Boot Starter

在開發工具 IDEA 通過 Maven 的 install 命令進行構建打包。或者在項目的目錄下,打開命令行窗口,使用mvn install命令進行構建打包。打包后,會在工程的 target 目錄下生成一個 jar 包,并且在 maven 本地倉庫也會生成相應的 jar 包。

如何手寫一個Spring Boot Starter

如何手寫一個Spring Boot Starter

如何手寫一個Spring Boot Starter

如何手寫一個Spring Boot Starter

使用自定義的 Starter

經過上面幾個步驟,我們自定義的 Starter 就開發好了,以下是在其他工程進行引入使用。在需要引用此 Starter 的工程的 pom.xml 文件中引入此依賴。

<dependency> <groupId>com.nobody</groupId> <artifactId>myjson-spring-boot-starter</artifactId> <version>0.0.1-SNAPSHOT</version></dependency>

刷新依賴,就能在項目的依賴庫中看到此依賴了。

如何手寫一個Spring Boot Starter

展開,還能查看此 Starter 可以配置的屬性項有哪些,如下:

如何手寫一個Spring Boot Starter

然后在需要用到的類中進行注入使用即可。

package com.nobody.controller;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import com.nobody.domain.Person;import com.nobody.service.MyJsonService;@RestController@RequestMapping('demo')public class DemoController { // 注入我們Starter中的服務類 @Autowired private MyJsonService myJsonService; @GetMapping() public String test() { Person p = new Person('Mr.nobody', 18, '拉斯維加斯'); // 調用服務方法 return myJsonService.objectToMyJson(p); }}

啟動項目,在瀏覽器中訪問此接口,得到如下結果:

如何手寫一個Spring Boot Starter

如果我們在 application.yml 文件中添加以下配置信息,然后再訪問接口的結果如下,也驗證了我們可以自定義 Starter 中默認的配置項。

nobody: json: prefixName: HH suffixName: KK

如何手寫一個Spring Boot Starter

當我們引入此 Starter 時,SpringBoot 會自動裝配,將實例化的 bean 放入 Spring 容器。但我們是否可控制 bean 要不要實例化并放入容器呢?答案是可以做到的。

我們只需要在自動裝配類或者類內的方法,通過 @ConditionalOnXXX 注解就能控制。例如如下所示,使用 Starter 使用者在他的項目的配置文件中填寫 nobody.json.enable 的值為 false,則就不會自動生成 MyJsonService 實例了。默認不填或者 nobody.json.enable 的值為 true 時,能自動生成 bean 放入容器。這樣用戶就能自己控制 bean 的實例化了。

// 創建MyJsonService對象,注入到Spring容器中@Bean@ConditionalOnProperty(name = 'nobody.json.enable', matchIfMissing = true)@ConditionalOnMissingBean(MyJsonService.class) // 當容器沒有此bean時,才注冊public MyJsonService myJsonService() { MyJsonService myJsonService = new MyJsonService(); myJsonService.setPrefixName(myJsonProperties.getPrefixName()); myJsonService.setSuffixName(myJsonProperties.getSuffixName()); return myJsonService;}

此演示項目已上傳到Github,如有需要可自行下載,歡迎 Star 。

https://github.com/LucioChn/myjson-spring-boot-starter

以上就是如何手寫一個Spring Boot Starter的詳細內容,更多關于手寫Spring Boot Starter的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久久久久色 | 欧美日韩夜夜| 在线亚洲自拍| 日韩中文字幕亚洲一区二区va在线| 伊人网在线播放| 精品国产第一福利网站| 久久男人天堂| 免费在线小视频| 私拍精品福利视频在线一区| 日韩一区三区| 欧美午夜精品一区二区三区电影| 欧美日韩水蜜桃| 欧美va亚洲va日韩∨a综合色| 亚洲午夜视频| 亚洲青青久久| 国产不卡人人| 91久久中文| 人人爱人人干婷婷丁香亚洲| 成人国产精品久久| 欧美亚洲在线日韩| 美女国产精品| 精品中国亚洲| 亚洲欧美日韩精品一区二区| 日本va欧美va精品发布| 国产日韩电影| 亚洲日产av中文字幕| 日本三级亚洲精品| 激情综合激情| 久久99久久久精品欧美| 亚洲免费在线| 四虎4545www国产精品 | 国产高清一区二区| 国产精品欧美一区二区三区不卡| 亚洲先锋成人| 日韩成人a**站| 色狠狠一区二区三区| 91精品国产调教在线观看| 国产乱码精品一区二区亚洲| 日韩精品电影| 精品一区二区三区视频在线播放| 99久精品视频在线观看视频| 在线一区免费| 91成人精品| 国产亚洲电影| 免费人成网站在线观看欧美高清| 日韩 欧美一区二区三区| 成人在线黄色| 免费人成黄页网站在线一区二区| 久久中文精品| 亚洲精品影视| www.九色在线| 日本免费在线视频不卡一不卡二| 欧美日韩一二三四| 国产欧美大片| 性欧美xxxx免费岛国不卡电影| 麻豆一区二区三| 天堂精品久久久久| 一本色道久久精品| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 精品国产免费人成网站| 爽好久久久欧美精品| 精品国模一区二区三区| 福利在线免费视频| 久久香蕉精品香蕉| 麻豆91小视频| 久久99蜜桃| 视频在线观看一区二区三区| 亚洲人成网站在线在线观看| 日韩制服丝袜av| 亚洲伊人精品酒店| 日韩精品免费视频一区二区三区 | 中文字幕av一区二区三区四区| 欧美~级网站不卡| 亚洲午夜黄色| 红桃视频国产精品| 久久视频精品| 99久久久久久中文字幕一区| 麻豆网站免费在线观看| 99久久精品费精品国产| 亚洲成人精品| 午夜久久免费观看| 丝袜美腿亚洲一区| 国产日本亚洲| 老色鬼精品视频在线观看播放| 日韩av一区二区在线影视| 国产欧美日韩一区二区三区四区| 国产福利资源一区| 亚洲1234区| 国产超碰精品| 黄色亚洲精品| 日韩福利在线观看| 久久精品国产免费| 亚洲天堂一区二区| 日韩欧美精品一区二区综合视频| 国产精品嫩模av在线| 极品av在线| 男女男精品网站| 国产精品传媒麻豆hd| 久久要要av| 日韩高清在线一区| 亚洲性色av| 亚洲精品美女| 电影天堂国产精品| 91精品丝袜国产高跟在线| zzzwww在线看片免费| 亚洲午夜在线| 蜜臀91精品国产高清在线观看| 国产精选久久| 欧美在线亚洲| 欧美亚洲免费| 美女毛片一区二区三区四区| 国产精成人品2018| 99re国产精品| 激情黄产视频在线免费观看| 日本视频中文字幕一区二区三区| 亚洲在线电影| 国产高清不卡| 久久精品资源| 国产九九精品| 亚洲欧美日本日韩| 国产成人调教视频在线观看| 日韩一区二区三区高清在线观看| 91精品在线观看国产| 麻豆91精品| 亚洲天堂免费| 在线一区二区三区视频| 中文欧美日韩| 亚洲成人日韩| 亚洲一区久久| 美女国产一区| 日韩毛片一区| 麻豆传媒一区二区三区| 久久99久久久精品欧美| 精品一区二区三区中文字幕视频 | 国产一区二区高清| 日韩精品一区第一页| 蜜桃视频一区二区三区| 中文字幕日韩亚洲| 奇米亚洲欧美| 免费观看亚洲天堂| 日本精品不卡| 综合欧美精品| 日韩欧美视频专区| 91高清一区| 91精品国产一区二区在线观看| 久久97久久97精品免视看秋霞| 亚洲欧美日本日韩| 国产精品入口久久| 欧美亚洲自偷自偷| 97久久精品| 国产精品成人国产| 成人在线观看免费视频| 91视频久久| 日韩免费在线| 久久理论电影| 在线国产一区二区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美一区免费| 国产第一亚洲| 亚洲欧美伊人| 亚洲一区日本| 日韩精品三区四区| 日本强好片久久久久久aaa| 四虎在线精品| 久久精品五月| 亚洲综合图色| 国产精品欧美一区二区三区不卡 | 日韩在线网址| 精品一区二区男人吃奶 | 国产亚洲一区| 91tv亚洲精品香蕉国产一区| 久久高清一区| 国产精品最新自拍| 欧美日韩国产v| 亚洲精品亚洲人成在线观看| 精品在线网站观看| 日韩中文字幕av电影| 国产精品啊v在线| 婷婷久久免费视频| 日韩黄色大片网站| 涩涩涩久久久成人精品| 精品网站999| 蜜桃视频免费观看一区| 国产精品一区二区美女视频免费看| 国产一区视频在线观看免费| 国产视频网站一区二区三区| 久久天堂精品| 青青伊人久久| 神马久久午夜| 亚洲一区二区小说| av在线最新| 亚洲一区二区小说| 久久青青视频| 日韩免费精品| 亚洲色图国产| 香蕉精品视频在线观看| 精品亚洲a∨| 精品中文字幕一区二区三区| 免费人成网站在线观看欧美高清| 亚洲伦乱视频|