SpringBoot中免除了大部分配置,但是对于一些特定的情况,还是需要我们进行手动配置的。
手动配置有两种方式:
1. SpringBoot为我们提供了application.properties配置文件,我们可以对默认的配置进行修改,还能加入一些第三方的配置,几乎所有配置都可以写到application.peroperties文件中,这个文件会被SpringBoot自动加载,
2. 自定义一个配置文件,但这些文件就需要我们进行手动加载。
备注1:SpringBoot可以识别两种格式的配置文件,yml与properties,我们可以将application.properties文件换成application.yml,这两个文件都可以被SpringBoot自动识别并加载,
但如果是自定义的配置文件,就最好还是使用properties格式的文件,因为SpringBoot中暂时还并未提供手动加载yml格式文件的功能(这里指注解方式)。
备注2:application.properties配置文件需要放置到指定的位置:src/main/resource目录下,一般自定义的配置文件也位于此目录之下。
如何使用配置项?
1. 只要是加载到Spring容器中的配置项都可以直接使用@Value("${key}")的方式来引用,一般将其配置在字段顶部,表示将配置项的值赋值给该字段。
2. 将这些配置项与一个JavaBean绑定起来使用,绑定一次,我们就可以随时使用。
绑定使用分两种情况:
1. 将application.properties中的配置与JavaBean类绑定
与属性绑定的JavaBean的类定义顶部加@Component注解和@ConfigurationProperties(prefix="key")注解,
前者的目的是为了JavaBean可以被SpringBoot项目启动时候被扫描到并加载到Spring容器之中,
后者为属性绑定注解,它的作用就是将指定的前缀的配置项的值与JavaBean的字段绑定,得与@EnableConfigurationProperties(JavaBean.class)配合使用,注意二者并非使用在同一位置,
注意:为了绑定的成功,字段的名称与配置项键的最后一个键名得相同,这样整个键在去掉前缀的情况下就和字段名称一致,以此来进行绑定。
2. 将自定义配置文件中的配置与Javabean绑定。
与之前的基本相同,只是配置不能自动加载,得手动加载
额外配置:
在JavaBean之上加上@PropertySource注解。
将@Component改为@Configuration,为什么这么做呢?
@Configuration注解的底层就是@Component,但是二者意义不同,@Configuration注解侧重配置之意,@Component侧重组件之意,当然配置也是项目组件之一,在这里我们要将配置文件属性与JavaBean绑定,当然更侧重配置之意。
@EnableConfigurationProperties(JavaBean.class)
@EnableConfigurationProperties注解@ConfigurationProperties注解配套使用,
标注有@ConfigurationProperties注解的Beans可以被使用标准的方式注册(使用@Bean注解),或者,直接用使用@EnableConfigurationProperties指定注册,例如:@EnableConfigurationProperties(JavaBean.class)
一个例子:
package com.donghao.model;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
@Configuration
@PropertySource("classpath:donghao.properties")
@ConfigurationProperties(prefix="donghao1")
public class Donghao {
private String name;
private String sex;
private String age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
}
定义控制器:DonghaoController
package com.donghao.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.donghao.model.Donghao;
@RestController
@RequestMapping("/donghao")
@EnableConfigurationProperties(Donghao.class)
public class DonghaoController {
@Autowired
Donghao donghao;
@Value("${donghao.name}")
private String name;
@Value("${donghao.sex}")
private String sex;
@Value("${donghao.age}")
private String age;
@RequestMapping("/hello")
public String hello(){
return "我的名字叫"+name+",我是"+sex+"生,今年"+age+"岁了!";
}
@RequestMapping("/ss")
public String ss(){
return donghao.getName()+donghao.getSex()+donghao.getAge();
}
}
定义启动入口类:DonghaoApplication.java
package com.donghao;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class DonghaoApplication {
public static void main(String[] args) {
SpringApplication.run(DonghaoApplication.class, args);
}
}