在编写项目代码时,我们要求更灵活的配置,更好的模块化整合。在 Spring Boot 项目中,为满足以上要求,我们将大量的参数配置在 application.properties 或 application.yml 文件中,通过 @ConfigurationProperties和@Value
注解,我们可以方便的获取这些参数值
@ConfigurationProperties能够批量注入配置文件的属性。
@ConfigurationProperties支持复杂属性类型
多数情况,我们传递给应用的参数是基本的字符串或数字。但是,有时我们需要传递诸如 List 的数据类型
List 和 Set还有map类型
@Value只能一个个指定。
@Value不支持复杂类型封装注解。
##datasource
#spring.datasource.primary.url=jdbc:mysql://localhost:3306/xyy_wms_zz1?createDatabaseIfNotExist=true&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true&useSSL=false&zeroDateTimeBehavior=convertToNull&pinGlobalTxToPhysicalConnection=true
#spring.datasource.primary.username=test
#spring.datasource.primary.password=test
#spring.datasource.primary.driverClassName= com.mysql.jdbc.Driver
#spring.datasource.primary.type= com.alibaba.druid.pool.DruidDataSource
@Value("${spring.atomikos.minPoolSize}")
private int minPoolSize;
@Value("${spring.atomikos.maxPoolSize}")
private int maxPoolSize;
@Value("${spring.atomikos.maxLifetime}")
private int maxLifetime;
@Value("${spring.atomikos.borrowConnectionTimeout}")
private int borrowConnectionTimeout;
@Value("${spring.atomikos.loginTimeout}")
private int loginTimeout;
@Value("${spring.atomikos.maintenanceInterval}")
private int maintenanceInterval;
@Value("${spring.atomikos.maxIdleTime}")
private int maxIdleTime;
@Value("${spring.atomikos.testQuery}")
private String testQuery;
@Bean(name = "DataSource")
@ConfigurationProperties(prefix = "spring.datasource.primary")
public DataSource MasterDataSource() {
DruidXADataSource dataSource = new DruidXADataSource();
dataSource.setDriverClassName(driverClass);
dataSource.setUrl(url);
dataSource.setUsername(user);
dataSource.setPassword(password);
@ConfigurationProperties(prefix = "spring.datasource.primary"),只需要指定一个前缀,就能绑定有这个前缀的所有属性值。