Springboot實現基於字首的自定義配置和自動提示功能
一、實現基於字首的自定義配置
1. 引入maven依賴
<!-- @ConfigurationProperties annotation processing (metadata for IDEs) -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
注:該依賴非常強大,有興趣可下載原始碼檢視實現方式,基於工廠模式
2.配置類
@Configuration
@ConfigurationProperties(prefix = "rocketmq.consume")
public class MqConsumeClientConfig {
private String nameServer;
private String groupName;
private String instanceName;
private String isTransaction;
private Map<String, String> topics;
private Map<String, String> tags;
}
@Configuration
@ConfigurationProperties(prefix = "rocketmq.produce")
public class MqProduceClientConfig {
private String nameServer;
private String groupName;
private String instanceName;
private String isTransaction;
private Map<String, String> topics;
private Map<String, String> tags;
@Bean(name = "mqProducer")
public DefaultRocketMqProducer defaultRocketMqProducer() {
return new DefaultRocketMqProducer();
}
@Bean(name = "producer")
public DefaultMQProducer defaultMQProducer( ) {
DefaultMQProducer producer = new DefaultMQProducer(groupName);
producer.setNamesrvAddr(nameServer);
producer.setVipChannelEnabled(false);
try {
producer.start();
} catch (MQClientException e) {
System.exit(1);
return null;
}
return producer;
}
}
@Configuration
@ConfigurationProperties(prefix = "rocketmq.produce")
配合使用,@Configuration 指明配置類;@ConfigurationProperties(prefix = "rocketmq.*") 指明字首
3. 配置檔案
rocketmq:
produce:
nameServer: 127.0.0.1:9876
groupName: ProduceAccountGroupDev
instanceName: ProduceAccountInstanceDev
isTransaction: 0
topics:
key1: AccountTopicDev
key2: AnswerTopicDev
tags:
key1: AccountTag1Dev
key2: AccountTag1Dev
consume:
nameServer: 127.0.0.1:9876
groupName: ConsumeAccountGroupDev
instanceName: ConsumeAccountInstanceDev
isTransaction: 0
topics:
key1: AccountTopicDev
key2: AnswerTopicDev
tags:
key1: All
key2: All
二、實現自動提示
一般在我們開發中,屬性檔案會產生一個自動提示,這個自定義提示也可以把我們的配置類新增到提示中。其實這是後設資料檔案氣的作用,
提供所有支援的配置屬性的詳細資訊。這些檔案旨在允許IDE開發人員在使用者使用application.properties 或application.yml檔案時提供上下文幫助和“程式碼完成” 。
主要的後設資料檔案是在編譯器通過處理所有被@ConfigurationProperties註解的節點來自動生成的。
1. 後設資料 spring-configuration-metadata.json
配置後設資料位於jars檔案中的META-INF/spring-configuration-metadata.json,它們使用一個具有”groups”或”properties”分類節點的簡單JSON格式:
{"groups": [
{
"name": "server",
"type": "org.springframework.boot.autoconfigure.web.ServerProperties",
"sourceType": "org.springframework.boot.autoconfigure.web.ServerProperties"
}
...
],"properties": [
{
"name": "server.port",
"type": "java.lang.Integer",
"sourceType": "org.springframework.boot.autoconfigure.web.ServerProperties"
},
{
"name": "server.servlet-path",
"type": "java.lang.String",
"sourceType": "org.springframework.boot.autoconfigure.web.ServerProperties"
"defaultValue": "/"
}
...
]}
每個”property”是一個配置節點,使用者可以使用特定的值指定它。例如,server.port和server.servlet-path可能在application.properties中如以下定義
server.port=9090
server.servlet-path=/home
“groups”是高階別的節點,它們本身不指定一個值,但為properties提供一個有上下文關聯的分組。例如,server.port和server.servlet-path屬性是server組的一部分。
注:不需要每個”property”都有一個”group”,一些屬性可以以自己的形式存在。
2. 配置後設資料步驟
1) 仍然是引入同樣的依賴
2) 在\resources\META-INF\下新增spring-configuration-metadata.json檔案。該檔案可以由idea生成。
3. 生成後設資料檔案
1)仍然是引入同樣的依賴
2)利用idea生成spring-configuration-metadata.json檔案
在idea中, Ctrl + Alt + S 快捷鍵開啟Settings,搜尋Annotation Processors,接下來勾住Enable annonation processing儲存;重新編譯專案。
此時可以在編譯後的檔案中看到自動生成的spring-configuration-metadata.json。
進一步開啟檔案如下:
{
"hints": [],
"groups": [
{
"sourceType": "com.feeler.interlive.config.MqConsumeClientConfig",
"name": "rocketmq.consume",
"type": "com.feeler.interlive.config.MqConsumeClientConfig"
},
{
"sourceType": "com.feeler.interlive.config.MqProduceClientConfig",
"name": "rocketmq.produce",
"type": "com.feeler.interlive.config.MqProduceClientConfig"
}
],
"properties": [
{
"sourceType": "com.feeler.interlive.config.MqConsumeClientConfig",
"name": "rocketmq.consume.group-name",
"type": "java.lang.String"
},
{
"sourceType": "com.feeler.interlive.config.MqConsumeClientConfig",
"name": "rocketmq.consume.instance-name",
"type": "java.lang.String"
},
{
"sourceType": "com.feeler.interlive.config.MqConsumeClientConfig",
"name": "rocketmq.consume.is-transaction",
"type": "java.lang.String"
},
{
"sourceType": "com.feeler.interlive.config.MqConsumeClientConfig",
"name": "rocketmq.consume.name-server",
"type": "java.lang.String"
},
{
"sourceType": "com.feeler.interlive.config.MqConsumeClientConfig",
"name": "rocketmq.consume.tags",
"type": "java.util.Map<java.lang.String,java.lang.String>"
},
{
"sourceType": "com.feeler.interlive.config.MqConsumeClientConfig",
"name": "rocketmq.consume.topics",
"type": "java.util.Map<java.lang.String,java.lang.String>"
},
{
"sourceType": "com.feeler.interlive.config.MqProduceClientConfig",
"name": "rocketmq.produce.group-name",
"type": "java.lang.String"
},
{
"sourceType": "com.feeler.interlive.config.MqProduceClientConfig",
"name": "rocketmq.produce.instance-name",
"type": "java.lang.String"
},
{
"sourceType": "com.feeler.interlive.config.MqProduceClientConfig",
"name": "rocketmq.produce.is-transaction",
"type": "java.lang.String"
},
{
"sourceType": "com.feeler.interlive.config.MqProduceClientConfig",
"name": "rocketmq.produce.name-server",
"type": "java.lang.String"
},
{
"sourceType": "com.feeler.interlive.config.MqProduceClientConfig",
"name": "rocketmq.produce.tags",
"type": "java.util.Map<java.lang.String,java.lang.String>"
},
{
"sourceType": "com.feeler.interlive.config.MqProduceClientConfig",
"name": "rocketmq.produce.topics",
"type": "java.util.Map<java.lang.String,java.lang.String>"
}
]
}
到此為止,已經實現了基於字首配置和自動提示功能
相關文章
- vue-自定義指令-實現提示功能Vue
- SpringBoot——自定義自動配置與起步依賴Spring Boot
- springboot+redis+Interceptor+自定義annotation實現介面自動冪等Spring BootRedis
- 如何實現自己的SpringBoot自動配置Spring Boot
- SpringBoot自定義攔截器實現IP白名單功能Spring Boot
- Spring Boot 自動配置的原理、核心註解以及利用自動配置實現了自定義 Starter 元件Spring Boot元件
- SpringBoot自動裝配-自定義StartSpring Boot
- SpringBoot(3)-MVC自動配置及自定義檢視控制器Spring BootMVC
- 【Spring Boot 使用記錄】kafka自動配置和自定義配置Spring BootKafka
- 基於 RecyclerView 實現的歌詞滾動自定義控制元件View控制元件
- 基於 Springboot+layui 實現介面自動化平臺Spring BootUI
- 關於微信分享自定義標題,說明,圖示基於PHP的功能實現PHP
- _008_SpringBoot_自定義配置Spring Boot
- Spring Boot 基礎: 使用 `@ConfigurationProperties` 實現自定義屬性的自動裝配Spring Boot
- 基於DotNetty實現自動釋出 - 專案的配置與發現Netty
- 基於SpringBoot如何實現一個點贊功能?Spring Boot
- 基於SpringBoot 、AOP與自定義註解轉義字典值Spring Boot
- SpringBoot應用使用自定義的ApplicationContext實現類Spring BootAPPContext
- SpringBoot的自動配置Spring Boot
- @ConfigurationProperties實現自定義配置繫結
- 基於Tensorflow + Opencv 實現CNN自定義影像分類OpenCVCNN
- springboot自動配置原理和啟動流程Spring Boot
- 自定義springboot啟動器Spring Boot
- video自定義實現視訊播放功能IDE
- SpringBoot中搭配AOP實現自定義註解Spring Boot
- Swagger基於SpringBoot實現SwaggerSpring Boot
- SpringBoot讀取自定義配置檔案Spring Boot
- springboot如何使用自定義配置檔案Spring Boot
- Vue結合原生js實現自定義元件自動生成VueJS元件
- SpringBoot的自動配置原理Spring Boot
- 基於RestAssured實現介面自動化REST
- SAP Spartacus 自定義Popover指令,如何實現彈出對話方塊自動關閉功能
- 自定義檔案上傳功能實現方法
- Python進階:自定義物件實現切片功能Python物件
- 基於 WebRTC 實現自定義編碼解析度傳送Web
- 基於Masstransit實現Eventbus的功能
- 實戰|如何自定義SpringBoot Starter?Spring Boot
- springboot+zuul(一)------實現自定義過濾器、動態路由、動態負載。Spring BootZuul過濾器路由負載