Spring Boot中的Properties



Spring Boot中的Properties

簡介

本文我們將會討怎么在Spring Boot中使用Properties。使用Properties有兩種方式,一種是java代碼的注解,一種是xml文件的配置。本文將會主要關注java代碼的注解。

使用注解注冊一個Properties文件

注冊Properties文件我們可以使用@PropertySource 注解,該注解需要配合@Configuration 一起使用。

@Configuration
@PropertySource("classpath:foo.properties")
public class PropertiesWithJavaConfig {
    //...
}

我們也可以使用placeholder來動態選擇屬性文件:

@PropertySource({ 
  "classpath:persistence-${envTarget:mysql}.properties"
})

@PropertySource也可以多次使用來定義多個屬性文件:

@PropertySource("classpath:foo.properties")
@PropertySource("classpath:bar.properties")
public class PropertiesWithJavaConfig {
    //...
}

我們也可以使用@PropertySources來包含多個@PropertySource:

@PropertySources({
    @PropertySource("classpath:foo.properties"),
    @PropertySource("classpath:bar.properties")
})
public class PropertiesWithJavaConfig {
    //...
}

使用屬性文件

最簡單直接的使用辦法就是使用@Value注解:

@Value( "${jdbc.url}" )
private String jdbcUrl;

我們也可以給屬性添加默認值:

@Value( "${jdbc.url:aDefaultUrl}" )
private String jdbcUrl;

如果要在代碼中使用屬性值,我們可以從Environment API中獲取:

@Autowired
private Environment env;
...
dataSource.setUrl(env.getProperty("jdbc.url"));

Spring Boot中的屬性文件

默認情況下Spring Boot 會讀取application.properties文件作為默認的屬性文件。當然,我們也可以在命令行提供一個不同的屬性文件:

java -jar app.jar --spring.config.location=classpath:/another-location.properties

如果是在測試環境中,我們可以使用@TestPropertySource 來指定測試的屬性文件:

@RunWith(SpringRunner.class)
@TestPropertySource("/foo.properties")
public class FilePropertyInjectionUnitTest {
 
    @Value("${foo}")
    private String foo;
 
    @Test
    public void whenFilePropertyProvided_thenProperlyInjected() {
        assertThat(foo).isEqualTo("bar");
    }
}

除了屬性文件,我們也可以直接以key=value的形式:

@RunWith(SpringRunner.class)
@TestPropertySource(properties = {"foo=bar"})
public class PropertyInjectionUnitTest {
 
    @Value("${foo}")
    private String foo;
 
    @Test
    public void whenPropertyProvided_thenProperlyInjected() {
        assertThat(foo).isEqualTo("bar");
    }
}

使用@SpringBootTest,我們也可以使用類似的功能:

@RunWith(SpringRunner.class)
@SpringBootTest(properties = {"foo=bar"}, classes = SpringBootPropertiesTestApplication.class)
public class SpringBootPropertyInjectionIntegrationTest {
 
    @Value("${foo}")
    private String foo;
 
    @Test
    public void whenSpringBootPropertyProvided_thenProperlyInjected() {
        assertThat(foo).isEqualTo("bar");
    }
}

@ConfigurationProperties

如果我們有一組屬性,想將這些屬性封裝成一個bean,則可以考慮使用@ConfigurationProperties。

@ConfigurationProperties(prefix = "database")
public class Database {
    String url;
    String username;
    String password;
 
    // standard getters and setters
}

屬性文件如下:

database.url=jdbc:postgresql:/localhost:5432/instance
database.username=foo
database.password=bar

Spring Boot將會自動將這些屬性文件映射成java bean的屬性,我們需要做的就是定義好prefix。

yaml文件

Spring Boot也支持yaml形式的文件,yaml對於層級屬性來說更加友好和方便,我們可以看下properties文件和yaml文件的對比:

database.url=jdbc:postgresql:/localhost:5432/instance
database.username=foo
database.password=bar
secret: foo
database:
  url: jdbc:postgresql:/localhost:5432/instance
  username: foo
  password: bar
secret: foo

注意yaml文件不能用在@PropertySource中。如果你使用@PropertySource,則必須指定properties文件。

Properties環境變量

我們可以這樣傳入property環境變量:

java -jar app.jar --property="value"

~~shell
java -Dproperty.name=“value” -jar app.jar


或者這樣:

~~~shell
export name=value
java -jar app.jar

環境變量有什么用呢? 當指定了特定的環境變量時候,Spring Boot會自動去加載application-environment.properties文件,Spring Boot默認的屬性文件也會被加載,只不過優先級比較低。

java代碼配置

除了注解和默認的屬性文件,java也可以使用PropertySourcesPlaceholderConfigurer來在代碼中顯示加載:

@Bean
public static PropertySourcesPlaceholderConfigurer properties(){
    PropertySourcesPlaceholderConfigurer pspc
      = new PropertySourcesPlaceholderConfigurer();
    Resource[] resources = new ClassPathResource[ ]
      { new ClassPathResource( "foo.properties" ) };
    pspc.setLocations( resources );
    pspc.setIgnoreUnresolvablePlaceholders( true );
    return pspc;
}

本文的例子可以參考:https://github.com/ddean2009/learn-springboot2/tree/master/springboot-properties

更多教程請參考 flydean的博客


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM