3.3.SpringBoot的属性注入
在上面的案例中,我们实验了java配置方式。不过属性注入使用的是@Value注解。这种方式虽然可
行,但是不够强大,因为它只能注入基本类型值。
在SpringBoot中,提供了一种新的属性注入方式,支持各种java基本数据类型及复杂类型的注入。
1)新建JdbcProperties,用来进行属性注入:
代码:
@ConfigurationProperties(prefix = “jdbc”) public class JdbcProperties {
private String url;
private String driverClassName;
private String username;
private String password;
// … 略
// getters 和 setters
}
在类上通过@ConfigurationProperties注解声明当前类为属性读取类
prefix="jdbc"读取属性文件中,前缀为jdbc的值。
在类上定义各个属性,名称必须与属性文件中jdbc.后面部分一致,并且必须具有getter和setter
方法
需要注意的是,这里我们并没有指定属性文件的地址,SpringBoot默认会读取文件名为
application.properties的资源文件,所以我们把jdbc.properties名称改为
application.properties
2)在JdbcConfiguration中使用这个属性:
通过@EnableConfigurationProperties(JdbcProperties.class)来声明要使用
JdbcProperties这个类的对象
然后你可以通过以下方式在JdbcConfiguration类中注入JdbcProperties:
1. @Autowired注入
@Configuration
@EnableConfigurationProperties(JdbcProperties.class) public class JdbcConfiguration {
@Autowired
private JdbcProperties jdbcProperties;
@Bean
public DataSource dataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setUrl(jdbcProperties.getUrl());
dataSource.setDriverClassName(jdbcProperties.getDriverClassName()); dataSource.setUsername(jdbcProperties.getUsername());
dataSource.setPassword(jdbcProperties.getPassword());
return dataSource;
}
}
2. 构造函数注入
@Configuration
@EnableConfigurationProperties(JdbcProperties.class) public class JdbcConfiguration {
private JdbcProperties jdbcProperties;
public JdbcConfiguration(JdbcProperties jdbcProperties){ this.jdbcProperties = jdbcProperties;
}
@Bean
public DataSource dataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setUrl(jdbcProperties.getUrl());
dataSource.setDriverClassName(jdbcProperties.getDriverClassName()); dataSource.setUsername(jdbcProperties.getUsername());
dataSource.setPassword(jdbcProperties.getPassword());
return dataSource;
}
}
3. @Bean方法的参数注入
@Configuration
@EnableConfigurationProperties(JdbcProperties.class) public class JdbcConfiguration {
// @Bean //把方法的返回值注入到spring容器
// public DataSource dataSource(JdbcProperties jdbcProperties){
// DruidDataSource dataSource = new DruidDataSource();
// dataSource.setDriverClassName(jdbcProperties.getDriverClassName());
// dataSource.setUrl(jdbcProperties.getUrl());
// dataSource.setUsername(jdbcProperties.getUsername());
// dataSource.setPassword(jdbcProperties.getPassword());
// return dataSource;
// }
本例中,我们采用第三种方式。 3)测试结果:
大家会觉得这种方式似乎更麻烦了,事实上这种方式有更强大的功能,也是SpringBoot推荐的注入方 式。两者对比关系:
package cn.itcast.springboot.config;
import com.alibaba.druid.pool.DruidDataSource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Component;
import javax.sql.DataSource;
/**
*
*/
@Configuration //声明一个类是一个java配置类,相当于一个xml配置文件
//@PropertySource(“classpath:jdbc.properties”) //读取资源文件
@EnableConfigurationProperties(JdbcProperties.class)
public class JdbcConfiguration {
// @Autowired
// private JdbcProperties jdbcProperties;
// public JdbcConfiguration(JdbcProperties jdbcProperties){
// this.jdbcProperties = jdbcProperties;
// }
// @Bean //把方法的返回值注入到spring容器
// public DataSource dataSource(){
// DruidDataSource dataSource = new DruidDataSource();
// dataSource.setDriverClassName(this.jdbcProperties.getDriverClassName());
// dataSource.setUrl(this.jdbcProperties.getUrl());
// dataSource.setUsername(this.jdbcProperties.getUsername());
// dataSource.setPassword(this.jdbcProperties.getPassword());
// return dataSource;
// }
// @Bean //把方法的返回值注入到spring容器
// public DataSource dataSource(JdbcProperties jdbcProperties){
// DruidDataSource dataSource = new DruidDataSource();
// dataSource.setDriverClassName(jdbcProperties.getDriverClassName());
// dataSource.setUrl(jdbcProperties.getUrl());
// dataSource.setUsername(jdbcProperties.getUsername());
// dataSource.setPassword(jdbcProperties.getPassword());
// return dataSource;
// }
@Bean //把方法的返回值注入到spring容器
@ConfigurationProperties(prefix = "jdbc")
public DataSource dataSource(){
DruidDataSource dataSource = new DruidDataSource();
return dataSource;
}
}
优势:
Relaxed binding:松散绑定
不严格要求属性文件中的属性名与成员变量名一致。支持驼峰,中划线,下划线等等转换,
甚至支持对象引导。比如:user.friend.name:代表的是user对象中的friend属性中的name
属性,显然friend也是对象。@value注解就难以完成这样的注入方式。
meta-data support:元数据支持,帮助IDE生成属性提示(写开源框架会用到)。
package cn.itcast.springboot.config;
import com.alibaba.druid.pool.DruidDataSource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Component;
import javax.sql.DataSource;
/**
*
*/
@Configuration //声明一个类是一个java配置类,相当于一个xml配置文件
//@PropertySource(“classpath:jdbc.properties”) //读取资源文件
@EnableConfigurationProperties(JdbcProperties.class)
public class JdbcConfiguration {
// @Autowired
// private JdbcProperties jdbcProperties;
// public JdbcConfiguration(JdbcProperties jdbcProperties){
// this.jdbcProperties = jdbcProperties;
// }
// @Bean //把方法的返回值注入到spring容器
// public DataSource dataSource(){
// DruidDataSource dataSource = new DruidDataSource();
// dataSource.setDriverClassName(this.jdbcProperties.getDriverClassName());
// dataSource.setUrl(this.jdbcProperties.getUrl());
// dataSource.setUsername(this.jdbcProperties.getUsername());
// dataSource.setPassword(this.jdbcProperties.getPassword());
// return dataSource;
// }
// @Bean //把方法的返回值注入到spring容器
// public DataSource dataSource(JdbcProperties jdbcProperties){
// DruidDataSource dataSource = new DruidDataSource();
// dataSource.setDriverClassName(jdbcProperties.getDriverClassName());
// dataSource.setUrl(jdbcProperties.getUrl());
// dataSource.setUsername(jdbcProperties.getUsername());
// dataSource.setPassword(jdbcProperties.getPassword());
// return dataSource;
// }
@Bean //把方法的返回值注入到spring容器
@ConfigurationProperties(prefix = "jdbc")
public DataSource dataSource(){
DruidDataSource dataSource = new DruidDataSource();
return dataSource;
}
}