SpringBoot創(chuàng)建自定義starter詳解
自定義starter
背景
(1)有時(shí)在公司內(nèi)部有時(shí)候自研中間件,需要被其他項(xiàng)目依賴(lài),這個(gè)時(shí)候直接引入starter,可以實(shí)現(xiàn)自動(dòng)化配置,可以做到對(duì)其他項(xiàng)目代碼無(wú)污染入侵。
(2)Spring Boot大量使用了starter模式,比如spring-boot-starter-redis,spring-boot-starter-jdbc,spring-boot-starter-data-jpa,spring-boot-starter-amqp,我們自己做一遍,了然于心,更能夠加深對(duì)Spring Boot的編程思想的理解與學(xué)習(xí)。
1.首先我們使用IDEA的Spring Initializr直接創(chuàng)建工程,引入web依賴(lài)
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
2.然后自帶的刪掉啟動(dòng)類(lèi),測(cè)試類(lèi),下面的maven插件。我們創(chuàng)建的starter屬于依賴(lài)包,不需要啟動(dòng)類(lèi)。否則在后續(xù)打jar包的時(shí)候會(huì)報(bào)錯(cuò)
<plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin>
3.創(chuàng)建配置類(lèi),可以為引入的starter配置相關(guān)屬性
@ConfigurationProperties(prefix = "spring.user") public class UserProperties { private String name; private Integer age; public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } }
4.創(chuàng)建Client端,定義相關(guān)方法操控屬性,模擬進(jìn)行數(shù)據(jù)處理。
public class UserClient { private UserProperties userProperties; public UserClient() { } public UserClient(UserProperties userProperties) { this.userProperties = userProperties; } public String getName(){ return userProperties.getName(); } public Integer getAge(){ return userProperties.getAge(); } }
5.自動(dòng)創(chuàng)建客戶(hù)端,創(chuàng)建UserClient實(shí)例
注意:@ConditionalOnProperty是用來(lái)控制是否啟用配置,它的name或者value屬性意義相同,區(qū)別是name是數(shù)組,value只綁定一個(gè)屬性。當(dāng)name或者value的屬性為havingValue指定值的時(shí)候配置才會(huì)生效,否則配置不生效。即在下面的配置中,只有當(dāng)enabled為true的時(shí)候配置才生效。
@Configuration @EnableConfigurationProperties(value = UserProperties.class) public class UserAutoConfigure { @Bean @ConditionalOnProperty(prefix = "spring.user", value = "enabled", havingValue = "true") public UserClient userClient(UserProperties userProperties) { return new UserClient(userProperties); } }
6.激活配置類(lèi)。在別的項(xiàng)目中如果想激活配置類(lèi)有兩種辦法,一個(gè)是通過(guò)spring.factories文件,一個(gè)是通過(guò)注解實(shí)現(xiàn),下面來(lái)分別實(shí)現(xiàn)這兩種。
通過(guò)spring.factories文件
在resources下創(chuàng)建META-INF目錄,在其下面創(chuàng)建spring.factories文件,如下聲明自己自動(dòng)配置類(lèi)UserAutoConfigure的路徑
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ com.anhe.springbootstarteruser.properties.UserAutoConfigure
或者通過(guò)注解實(shí)現(xiàn),只需要在主類(lèi)上添加@EnableUserClient注解,不需要編寫(xiě)spring.factories文件,就可以激活配置類(lèi),注解定義如下:
關(guān)鍵在于@Import注解,他也申明了自動(dòng)配置類(lèi)UserAutoConfigure的路徑
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Inherited @Import({UserAutoConfigure.class}) public @interface EnableUserClient { }
7.配置application.properties提示信息,我們更傾向于在添加配置的時(shí)候能夠看到配置信息或者默認(rèn)值之類(lèi)的,可以按如下方法配置:
在META-INF下創(chuàng)建文件spring-configuration-metadata.json,內(nèi)容如下:
{ "properties": [ { "name": "spring.user.name", "defaultValue": "cxytinadi" }, { "name": "spring.user.enabled", "type": "java.lang.Boolean", "defaultValue": false }, { "name": "spring.user.age", "type": "java.lang.Integer", "defaultValue": 18 } ] }
然后在其他項(xiàng)目配置的時(shí)候就會(huì)自動(dòng)出現(xiàn)提示,包括配置的默認(rèn)值。
8.然后在Terminal輸入:
mvn clean install
相關(guān)jar包就會(huì)打包到本地倉(cāng)庫(kù),本地其他項(xiàng)目就可以直接使用。
9.demo示例:
其他項(xiàng)目引入依賴(lài):
<dependency> <groupId>com.anhe</groupId> <artifactId>spring-boot-starter-user</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency>
application.properties加入配置
spring.user.age=20 spring.user.name=tystsyts spring.user.enabled=true
如果直接是配置注解啟動(dòng),需要在主類(lèi)上加上@EnableUserClient注解,然后在新項(xiàng)目編寫(xiě)controller驗(yàn)證:
@RestController public class UserController { @Autowired private UserClient userClient; @GetMapping("/user") public Map<String,Object> getUserInfo() { Map<String, Object> map = new HashMap<>(); map.put("name",userClient.getName()); map.put("age",userClient.getAge()); return map; } }
瀏覽器訪問(wèn)//localhost:8080/user就可以獲取到結(jié)果
{ "name": "tystsyts", "age": 20 }
到此這篇關(guān)于SpringBoot創(chuàng)建自定義starter詳解的文章就介紹到這了,更多相關(guān)SpringBoot自定義starter內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java使用POI讀取properties文件并寫(xiě)到Excel的方法
這篇文章主要介紹了java使用POI讀取properties文件并寫(xiě)到Excel的方法,涉及java操作properties文件及Excel文件的相關(guān)技巧,需要的朋友可以參考下2015-06-06springboot集成fastDfs過(guò)程代碼實(shí)例
這篇文章主要介紹了springboot集成fastDfs過(guò)程代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12Java和c語(yǔ)言隨機(jī)數(shù)Random代碼詳細(xì)
這篇文章主要介紹Java和c語(yǔ)言得隨機(jī)數(shù)Random,隨機(jī)數(shù)的用處在生活中比較少見(jiàn),但是用處并不少,比如一些小游戲的制作等等。下面我們就一起來(lái)學(xué)習(xí)這篇關(guān)于Java和c隨機(jī)數(shù)Random得文章吧2021-10-10為什么Java中都不用a.equals(b)判斷對(duì)象相等
在面試中經(jīng)常會(huì)被問(wèn),a.equals(b)和“==”的區(qū)別,那么a.equals(b)能不能判斷對(duì)象相等,本文就來(lái)詳細(xì)的介紹一下2021-06-06微服務(wù)間調(diào)用Retrofit在Spring?Cloud?Alibaba中的使用
這篇文章主要為大家介紹了微服務(wù)間調(diào)用Retrofit在Spring?Cloud?Alibaba中的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Jackson反序列化@JsonFormat 不生效的解決方案
這篇文章主要介紹了Jackson反序列化@JsonFormat 不生效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08解決idea 從mapper方法直接點(diǎn)進(jìn)xml文件的問(wèn)題
這篇文章主要介紹了解決idea 從mapper方法直接點(diǎn)進(jìn)xml文件的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02