SpringBoot隨機數設置及參數間引用的操作步驟

自定義配置

SpringBoot免除瞭項目中大部分手動配置,可以說,幾乎所有的配置都可以寫在全局配置文件application.peroperties中,SpringBoot會自動加載全局配置文件從而免除我們手動加載的煩惱。但是,如果我們自定義瞭配置文件,那麼SpringBoot是無法識別這些配置文件的,此時需要我們手動加載。

接下來,將針對SpringBoot的自定義配置文件及其加載方式進行講解。

(1)使用@PropertySource加載配置文件

我們可以使用@PropertySource註解結合@Configuration註解配置類的方式來加載自定義配置文件,@PropertySource註解用於指定自定義配置文件的具體位置和名稱。同時,為瞭保證SpringBoot能夠掃描該註解,還需要在類上添加@Configuration註解將實體類作為自定義配置類。

如果需要將自定義配置文件中的屬性值註入到對應類的屬性中,可以使用@ConfigurationProperties註解或者@Value註解進行屬性值註入。

操作步驟:

1、在SpringBoot項目的resources目錄下新建一個名為test.properties的自定義配置文件,在該配置文件中編寫需要設置的配置屬性:

# 對實體類對象MyProperties進行屬性配置
test.id=1
test.name=test

2、在com.hardy.springboot_demo.pojo包下新建一個配置類MyProperties,提供test.properties自定義配置文件中對應的屬性,並根據@PropertySource註解的使用進行相關的配置:

package com.hardy.springboot_demo.pojo;

/**
 * @Author: HardyYao
 * @Date: 2021/5/31
 */

import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;

@Configuration // 自定義配置類
@PropertySource("classpath:test.properties") // 指定自定義配置文件的文件位置和文件名稱
@EnableConfigurationProperties(MyProperties.class) // 開啟對應配置類的屬性註入功能
@ConfigurationProperties(prefix = "test") // 指定配置文件註入屬性前綴
public class MyProperties {

    private int id;

    private String name;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "MyProperties{" +
                "id=" + id +
                ", name='" + name + '\'' +
                '}';
    }
}

這裡主要是新建一個自定義配置類,通過相關註解引入瞭自定義的配置文件,並完成瞭自定義屬性值的註入。

針對上述的幾個註解,進行逐一講解:

  • @Configuration註解表示當前類是一個自定義配置類,並添加為Spring容器的組件,這裡也可以使用傳統的@Component註解實現相同的功能;
  • @PropertySource(“classpath:test.properties”)註解指定瞭定義配置文件的文件位置和文件名稱,此處表示自定義配置文件為classpath類路徑下的test.properties文件;
  • @ConfigurationProperties(prefix = “test”)將上述自定義配置文件test.properties中以test開頭的屬性值註入到該配置類屬性中;
  • 如果配置類上使用的是@Component註解而非@Configuration註解,那麼@EnableConfigurationProperties註解還可以省略。

3、編寫測試方法進行測試:

@Autowired
private MyProperties myProperties;
@Test
void myPropertiesTest() {
    System.out.println(myProperties);
}

測試結果:

(2)使用@Configuration編寫自定義配置類

在SpringBoot框架中,推薦使用配置類的方式向容器中添加和配置組件。

在SpringBoot框架中,通常使用@Configuration註解定義一個配置類,SpringBoot會自動掃描和識別配置類,從而替換傳統Spring框架中的XML配置文件。

當自定義一個配置類後,還需要在類中的方法上加上@Bean註解進行組件配置,將方法的返回對象註入到Spring容器中,並且組件名稱默認使用的是方法名,當然也可以使用@Bean註解的name或value屬性自定義組件的名稱。

操作步驟:

1、在com.hardy.springboot_demo包下新建一個config包,並在該包下新建一個MyService類,該類中不需要寫任何代碼:

package com.hardy.springboot_demo.config;

/**
 * @Author: HardyYao
 * @Date: 2021/5/31
 */
public class MyService {
}

由於該類目前沒有任何配置和註解,因此還無法正常被SpringBoot掃描和識別。

2、在config包下,新建一個MyConfig類,並使用@Configuration註解將該類聲明為一個配置類,該類的內容如下:

package com.hardy.springboot_demo.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @Author: HardyYao
 * @Date: 2021/5/31
 */
@Configuration // 定義該類為一個配置類
public class MyConfig {

    /**
     * 將返回值對象作為組件添加到Spring容器中,該組件id默認為方法名
     * @return
     */
    @Bean
    public MyService myService(){
        return new MyService();
    }

}

MyConfig是@Configuration註解聲明的配置類(類似於聲明瞭一個XML配置文件),該配置類會被SpringBoot自動掃描識別。

使用@Bean註解的myService()方法,其返回值對象會作為組件添加到Spring容器中(類似於XML配置文件中的標簽配置),並且該組件id默認為方法名myService。

3、編寫測試方法進行測試

@Autowired
private ApplicationContext applicationContext;
    
@Test
void iocTest() {
    System.out.println(applicationContext.containsBean("myService"));
}

上述代碼中,先通過@Autowired註解註入Spring容器示例ApplicationContext,然後在測試方法iocTest()中測試查看該容器中是否包含id為myService的組件。

執行測試方法iocTest(),運行結果如下:

從測試結果可以看出,測試方法iocTest()運行成功,顯示運行結果為true,表示Spirng的IOC容器中也包含瞭id為myService的實例對象組件,說明使用自定義配置類的形式完成瞭向Spring容器進行組件的添加和配置。

隨機數設置及參數間引用

在SpringBoot配置文件中設置屬性時,除瞭可以像前面示例中顯示的配置屬性值外,還可以使用隨機值和參數間引用對屬性值進行設置。下面,針對配置文件中這兩種屬性值的設置方式進行講解。

隨機值設置

在SpringBoot配置文件中,隨機值設置使用到瞭SpringBoot內嵌的RandomValuePropertySource類,對一些隱秘屬性值或者測試用例屬性值進行隨機值註入。

隨機值設置的語法格式為${random.xx},xx表示需要制定生成的隨機數類型和范圍,它可以生成隨機的整數、uuid或字符串,示例代碼如下:

my.secret=${random.value} // 配置隨機值
my.number=${random.int} // 配置隨機整數
my.bignumber=${random.long} // 配置隨機long類型數
my.uuid=${random.uuid} // 配置隨機uuid類型數
my.number.less.than.ten=${random.int(10)} // 配置小於10的隨機整數
my.number.in.range=${random.int[1024,65536]} // 配置范圍在[1024,65536]之間的隨機整數

上述代碼中,使用RandomValuePropertySource類中random提供的隨機數類型,分別展示瞭不同類型隨機值的設置示例。

參數間引用

在SpringBoot配置文件中,配置文件的屬性值還可以進行參數間的引用,也就是在後一個配置的屬性值中直接引用先前定義過的屬性,這樣就可以直接解析其中的屬性值瞭。

使用參數間引用的好處就是,在多個具有相互關聯的配置屬性中,隻需要對其中一處屬性進行預先配置,那麼其他地方都可以引用,省去瞭後續多處修改的麻煩。

參數間引用的語法格式為${xx},xx表示先前在配置文件中已經配置過的屬性名,示例代碼如下:

app.name=MyApp
app.description=${app.name} is a Spring Boot application

上述參數間引用設置示例中,先設置瞭“app.name=MyApp”,將app.name屬性的屬性值設置為瞭MyApp;接著,在app.description屬性配置中,使用${app.name}對前一個屬性進行瞭引用。

接下來,通過一個案例來演示使用隨機值設置以及參數間引用的方式進行屬性設置的具體使用和效果,具體步驟如下:

1、打開全局配置文件application.properties,在該配置文件中分別通過隨機值設置和參數間引用來配置兩個屬性,示例代碼如下:

# 隨機值設置以及參數間引用配置
hardy.age=${random.int[20,30]}
hardy.description=hardy的年齡可能是${hardy.age}

在上述application.properties配置文件中,先使用隨機數設置瞭hardy.age的屬性值,該屬性值的取值范圍在[10,20]之間,隨後使用參數間引用配置瞭hardy.description屬性。

2、在項目的測試類中添加description屬性,並將配置文件中hardy.description的屬性進行註入,然後新增一個測試方法進行測試,測試代碼如下:

@Value("${hardy.description}")
private String description;

@Test
void placeholderTest() {
    System.out.println(description);
}

在上述代碼中,通過@Value(“${hardy.description}”)註解將配置文件中的hardy.description屬性值註入到瞭對應的description屬性中,在測試方法placeholderTest()中對該屬性值進行瞭輸出打印。

執行測試方法後,控制臺輸出結果如下所示:

可以看到,測試方法placeholderTest()成功打印出瞭description屬性的註入內容(age的取值始終在[20,30]之間隨機顯示),該內容與配置文件中配置的屬性值保持一致。

以上就是SpringBoot隨機數設置及參數間引用的配置方法的詳細內容,更多關於SpringBoot參數間引用隨機數設置的資料請關註WalkonNet其它相關文章!

推薦閱讀: