激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 迅速學會@ConfigurationProperties的使用操作

迅速學會@ConfigurationProperties的使用操作

2022-02-10 15:00工人最光榮 Java教程

這篇文章主要介紹了迅速學會@ConfigurationProperties的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

 

@ConfigurationProperties的使用

@ConfigurationProperties標簽可以把.yml文件里的配置讀取到類里

比如,我需要把釘釘小程序的app-key和app-secret放在application.yml文件里面,方便我的配置,那么我們就這樣在application.yml里編寫:

dingding:
  app-key: "dings9oi56464654gfqrfms"
  app-secret: "58786163213546161231321231321aAhbCa8Vw2EVBJiw9_96vd"

現在我們新建一個類,使用注解

 

 

@ConfigurationProperties

來獲得這些值:

@Setter
@Getter
@ConfigurationProperties(prefix = "dingding")
public class AppInfoConfigProperties {
    private String APP_KEY;
    private String APP_SECRET;
}

注意,被 @ConfigurationProperties 修飾的類必須帶有set方法,否則無法獲得配置值。

這樣一來,AppInfoConfigProperties就可以拿到application.yml里的配置,這里的匹配是寬松匹配,寫成

private String appKey;
private String appSecret;

也是可以獲取到值的。

在經過以上的步驟后,AppInfoConfigProperties本身并沒有加入容器,也就拿不到他的值,下一步我們把它注冊成一個Bean:

@EnableConfigurationProperties(AppInfoConfigProperties.class)
@Configuration
public class AppInfoConfig {
    @Autowired
    AppInfoConfigProperties appInfoConfigProperties;
    @Bean("appInfoUtil")
    public AppInfoUtil appInfoUtil(){
        return new AppInfoUtil(appInfoConfigProperties.getAPP_KEY(),appInfoConfigProperties.getAPP_SECRET());
    }
}

這里我們使用了 @EnableConfigurationProperties(AppInfoConfigProperties.class) 來將 AppInfoConfigProperties給注冊到了容器里,同時通過 @Autowired拿到了它的值。

至此,application.yml文件中的值已被成功獲取到了容器里。

以下是AppInfoUtil 的結構:

@Getter
@Setter
@AllArgsConstructor
public class AppInfoUtil {
    private String appKey;
    private String appSecret;
    @Override
    public String toString() {
        return String.format("本小程序的APP-KEY:[%s];本小程序的APP-SECRET:[%s]",this.getAppKey(),this.getAppSecret());
    }
}

為什么不直接使用AppInfoConfigProperties?

原因是因為AppInfoUtil可能會根據業務的需要做出很多的增強功能,所以與配置分離。

 

注解@ConfigurationProperties使用方法

最近在思考使用java config的方式進行配置,java config是指基于java配置的spring。傳統的Spring一般都是基本xml配置的,后來spring3.0新增了許多java config的注解,特別是spring boot,基本都是清一色的java config。

 

Spring配置方式

第一階段:xml配置

在spring 1.x時代,使用spring開發滿眼都是xml配置的bean,隨著項目的擴大,

我們需要把xml配置文件分放到不同的配置文件中,那時候需要頻繁地在開發的類和配置文件間切換。

第二階段:注解配置

在spring 2.x時代,隨著JDK1.5帶來的注解支持,spring提供了聲明bean的注解,大大減少了配置量。這時spring圈子存在一種爭論:注解配置和xml配置究竟哪個更好?我們最終的選擇是應用的基本配置用xml,業務配置用戶注解。

第三階段:Java配置(java config)

從spring 3.x到現在,spring提供了Java配置的能力,使用Java配置更好的理解

配置的bean。spring 4.x和spring boot都推薦使用Java配置。

Spring IOC有一個非常核心的概念――Bean。由Spring容器來負責對Bean的實例化,裝配和管理。XML是用來描述Bean最為流行的配置方式。但隨著Spring的日益發展,越來越多的人對Spring提出了批評。“Spring項目大量的爛用XML”就是最為嚴勵的一個批評。由于Spring會把幾乎所有的業務類都以Bean的形式配置在XML文件中,造成了大量的XML文件。使用XML來配置Bean失去了編譯時的類型安全檢查。大量的XML配置使得整個項目變得更加復雜。

隨著JAVA EE 5.0的發布,其中引入了一個非常重要的特性――Annotations(注釋)。注釋是源代碼的標簽,這些標簽可以在源代碼層進行處理或通過編譯器把它熔入到class文件中。在JAVA EE5以后的版本中,注釋成為了一個主要的配置選項。Spring使用注釋來描述Bean的配置與采用XML相比,因類注釋是在一個類源代碼中,可以獲得類型安全檢查的好處。可以良好的支持重構。

JavaConfig就是使用注釋來描述Bean配置的組件。JavaConfig 是Spring的一個子項目, 比起Spring,它還是一個非常年青的項目。目前的版本是1.0 M2。使用XML來配置Bean所能實現的功能,通過JavaConfig同樣可以很好的實現。

下面具體講一講@ConfigurationProperties使用方法

@ConfigurationProperties

Spring源碼中大量使用了ConfigurationProperties注解,比如server.port就是由該注解獲取到的,通過與其他注解配合使用,能夠實現Bean的按需配置。

該注解有一個prefix屬性,通過指定的前綴,綁定配置文件中的配置,該注解可以放在類上,也可以放在方法上

迅速學會@ConfigurationProperties的使用操作

可以從注解說明中看到,當將該注解作用于方法上時,如果想要有效的綁定配置,那么該方法需要有@Bean注解且所屬Class需要有@Configuration注解。

簡單一句話概括就是:Sring的有效運行是通過上下文(Bean容器)中Bean的配合完成的,Bean可以簡單理解成對象,有些對象需要指定字段內容,那么這些內容我們可以通過配置文件進行綁定,然后將此Bean歸還給容器

 

作用于方法

比較常見的就是配置讀寫分離的場景。

配置文件內容

#數據源
spring.datasource.druid.write.url=jdbc:mysql://localhost:3306/jpa
spring.datasource.druid.write.username=root
spring.datasource.druid.write.password=1
spring.datasource.druid.write.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.druid.read.url=jdbc:mysql://localhost:3306/jpa
spring.datasource.druid.read.username=root
spring.datasource.druid.read.password=1
spring.datasource.druid.read.driver-class-name=com.mysql.jdbc.Driver

java代碼

@Configuration
public class DruidDataSourceConfig {
    /**
     * DataSource 配置
     * @return
     */
    @ConfigurationProperties(prefix = "spring.datasource.druid.read")
    @Bean(name = "readDruidDataSource")
    public DataSource readDruidDataSource() {
        return new DruidDataSource();
    }
    /**
     * DataSource 配置
     * @return
     */
    @ConfigurationProperties(prefix = "spring.datasource.druid.write")
    @Bean(name = "writeDruidDataSource")
    @Primary
    public DataSource writeDruidDataSource() {
        return new DruidDataSource();
    }
}

也許有的人看到這里會比較疑惑,prefix并沒有指定配置的全限定名,那它是怎么進行配置綁定的呢?

相信大家肯定了解@Value注解,它可以通過全限定名進行配置的綁定,這里的ConfigurationProperties其實就類似于使用多個@Value同時綁定,綁定的對象就是DataSource類型的對象,而且是 隱式綁定 的,意味著在配置文件編寫的時候需要與對應類的字段名稱 相同,比如上述spring.datasource.druid.write.url=jdbc:mysql://localhost:3306/jpa ,當然了,你也可以隨便寫個配置,比如 spring.datasource.druid.write.uuu=www.baidu.com,此時你只需要在注解中加上以下參數即可

迅速學會@ConfigurationProperties的使用操作

以上就完成了多個數據源的配置,為讀寫分離做了鋪墊

 

作用于Class類及其用法

配置文件內容

spring.datasource.url=jdbc:mysql://127.0.0.1:8888/test?useUnicode=false&autoReconnect=true&characterEncoding=utf-8
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

java代碼

@ConfigurationProperties(prefix = "spring.datasource")
@Component
public class DatasourcePro {
    private String url;
    private String username;
    private String password;
    // 配置文件中是driver-class-name, 轉駝峰命名便可以綁定成
    private String driverClassName;
    private String type;
    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;
    }
    public String getDriverClassName() {
        return driverClassName;
    }
    public void setDriverClassName(String driverClassName) {
        this.driverClassName = driverClassName;
    }
    public String getType() {
        return type;
    }
    public void setType(String type) {
        this.type = type;
    }
}

用法

@Controller
@RequestMapping(value = "/config")
public class ConfigurationPropertiesController {
    @Autowired
    private DatasourcePro datasourcePro;
    @RequestMapping("/test")
    @ResponseBody
    public Map<String, Object> test(){
        Map<String, Object> map = new HashMap<>();
        map.put("url", datasourcePro.getUrl());
        map.put("userName", datasourcePro.getUsername());
        map.put("password", datasourcePro.getPassword());
        map.put("className", datasourcePro.getDriverClassName());
        map.put("type", datasourcePro.getType());
        return map;
    }
}

 

總結

@ConfigurationProperties 和 @value 有著相同的功能,但是 @ConfigurationProperties的寫法更為方便

@ConfigurationProperties 的 POJO類的命名比較嚴格,因為它必須和prefix的后綴名要一致, 不然值會綁定不上, 特殊的后綴名是“driver-class-name”這種帶橫杠的情況,在POJO里面的命名規則是 下劃線轉駝峰 就可以綁定成功,所以就是 “driverClassName”

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/nsplnpbjy/article/details/106359154

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 激情久久精品 | 国产一级做a爱片在线看免 日日草夜夜 | 欧美日韩在线视频观看 | 成人av一区二区免费播放 | 成人欧美日韩一区二区三区 | 久久亚色 | 特黄一区二区三区 | 久久久av亚洲男天堂 | 欧美久久久久久久久 | 午夜影院操 | 毛片久久| 成年人网站视频免费 | 97人操| xxxxxx性| 欧美a在线观看 | 精品在线观看一区 | 欧美一级成人 | 久久久一区二区三区四区 | 天天天干夜夜夜操 | 福利在线小视频 | 亚洲成人午夜精品 | 国产色爱综合网 | 日本精品久久久久久草草 | 欧美国产成人在线 | 欧洲成人一区二区 | 国产乱淫a∨片免费观看 | 27xxoo无遮挡动态视频 | 国产精品视频在线观看免费 | 国产羞羞视频在线观看 | 哪里可以看免费的av | 国产成人视屏 | 国产精品区一区二区三区 | 欧美性生活视频免费看 | 在线看一区二区三区 | 中文字幕涩涩久久乱小说 | 国产精品成年片在线观看, 日韩毛片网 | 电视剧全部免费观看 | 一级观看免费完整版视频 | 亚州欧美视频 | 在线91视频| av在线免费观看网站 |