springboot的四种属性注入(注解)

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;
}

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值