今年是我毕业后入职的第二年了,在我工作的这段时间里,我发现越来越多的公司都要求有 SpringBoot 实际使用经验或者 SpringCloud 实际使用经验,但是由于我对SpringBoot知之甚少,为了巩固我学到的东西,我准备学习一下 SpringBoot 在开发过程中帮开发者省去了神马操作。
在之前还是使用SpringMVC的时代中,我们经常使用如下注解将配置文件的属性注入到Bean类中
// 声明当前java类是一个配置类
@Configuration
// 加载配置文件,文件名(application)可以自定义
@PropertySource("classpath:application.properties")
// 将属性文件(一般是application.properties)中的server.port属性注入到变量port中
@Value("${server.port}")
String port;
在上面获取配置属性时,使用了@Value注解。这种方式虽然可行,但是不够强大,因为它只能注入基本类型值。
而在SpringBoot中,提供了一种新的属性注入方式,支持各种java基本数据类型及复杂类型的注入,代码如下:
application.properties
user.name = 小明
user.age = 10
或者
application.yml
user:
name: 小明
age: 10
以上两种配置方式均可
// 将配置文件中前缀为“user”的属性注入到成员变量中
@ConfigurationProperties(prefix = "user")
public class PersonProperties {
private String name;
private Integer age;
// getters 和 setters
}
在使用类上
@Configuration
@EnableConfigurationProperties(PersonProperties.class)
public class GetConfig {
@Bean
public User getUser(PersonProperties person) {
User user = new User();
user.setName(person.getName());
user.setAge(person.getAge());
return user;
}
}
注:
@ConfigurationProperties(prefix = “user”):使用这个注解时,若没有指定配置文件地址时,默认是application.properties,
prefix = “user”:读取属性文件中,前缀为user的值,若不写,则默认从全局配置文件中获取值然后进行注入
如果这个注解在类上声明,则表示可以在任何地方使用以下三种方式进行注入:
- 第一种:@Autowired注解:
@Autowired
private PersonProperties person;
- 第二种:构造方法
private PersonProperties person;;
public GetConfig(PersonProperties person){
this.person = person;
}
- 第三种:声明有@Bean的方法参数注入
@Bean
// 声明要注入的属性前缀,SpringBoot会自动把相关属性通过set方法注入到User对象中
@ConfigurationProperties(prefix = "user")
public User getUser(PersonProperties person){
User user = new User();
return user;
}
如果只想让配置在局部生效,则可以将注解放在有@Bean的方法上,SpringBoot就会自动调用这个Bean的set方法,完成注入。使用的前提是:该类必须有对应属性的set方法!
@Configuration:这个注解表明该类是一个配置类,并注册成为Spring组件(在其源码中包含有**@Component**注解)
@EnableConfigurationProperties(value=PersonProperties.class):声明在这个类注入java配置类,
value:表明要使用的java配置类
通过以上的学习,了解到在SpringBoot中我们可以更加灵活的为变量注入属性值,还可以为对象写入属性值,而不必再对象的每一个属性为书写@Value注解,并且不需要特别注意属性名和变量名需要保持高度一致的规范了。
在SpringBoot优雅的注入的方式——松散绑定(Relaxed binding):
- 不严格要求属性文件中的属性名与成员变量名一致。支持驼峰,中划线,下划线等等转换,甚至支持对象引导。比如:user.department.name 代表的是user对象中的department属性中的name属性,显然department也是对象。@value注解就难以完成这样的注入方式。
- meta-data support:元数据支持,帮助IDE生成属性提示(写开源框架会用到)。这个我暂时还没学到