spring boot读取yml配置文件的几种方式

实际项目中一般使用application.yml作为配置文件,下面介绍yml的规范和如何读取yml。

yml文件书写规范:

1、通过缩进(推荐两个空格)区分层次(不能使用tab缩进,否则会报错),较properties更具可读性

2、属性名命名可以使用驼峰命名法,也可以使用-或者_,比如用户名可以是userName,user-name,USER_NAME,意思都是一样的

3、键值对的书写形式,key跟着冒号,然后空格(不能少),然后是value

各类数据书写形式:

1、数字,字符串,布尔等

# key: value形式
name: zs
age: 20
enable: true

2、数组,集合(List,Set)

# 方式一:换行缩进,使用-表示一个元素(常用)
# 如Java bean中的List<String> tels 或者 String[] tels
tels: 
  - 110
  - 120
# List<Users> users
users: 
  - name: zs
    age: 20
  - name: ls
    age: 30
# 方式二:单行配置
tels: 110, 120
users: {name: zs, age: 20}, {name: ls, age: 30}

3、Map和对象

# 方式一:多行配置
# 如Map<String, Integer> score或者Score score
score:
  chinese: 95
  english: 90
# 方式二:单行配置
score: {chinese: 95, english: 90}

读取yml文件:

先在application.yml中写好相关配置:

user:
  user-name: Mr.Zhang
  age: 38
  tels:
    - 110
    - 120
  score:
    chinese: 95
    english: 90
  users:
    - user-name: zs
      age: 5
    - user-name: ls
      age: 12

一、@Value注解(值绑定)

定义一个JavaBean,提供get和set方法(必须),用于接收从yml读取的数据

@Data
@Component
public class Users {

    /**
     * @Value 值绑定
     * 在每个对应的属性上加@Value注解,注解中的内容填写yml中对应的属性,
     * 使用@Value注解时,yml中的属性名和JavaBean中的属性名可以不对应,但是数据类型需要对应
     */
    @Value("${user.userName}")
    private String name;
    @Value("${user.age}")
    private Integer age;
    @Value("${user.tesl}")
    private String[] tels;
    @Value("${user.score}")
    private Map<String, Integer> score;
    @Value("${user.users}")
    private List<Users> children;
    
}

二、@ConfigurationProperties注解(松散绑定)

定义一个JavaBean,提供get和set方法,用于接收从yml读取的数据

/**
 * ConfigurationProperties 松散绑定,只需要通过prefix属性指定属性参数名的前缀即可
 * 松散绑定的bean属性名需要跟yml中的属性名对应,但是不需要精确匹配,
 * yml可依据约定使用驼峰(如:userName)、"-"线(如:user-name)、全大写加上"_"(如:USER_NAME)
 */
@Data
@Component
@ConfigurationProperties(prefix = "user")
public class Users {

    private String userName;
    private Integer age;
    private String[] tels;
    private Map<String, Integer> score;
    private List<Teacher> oldTeachers;
    private List<Teacher> newTeachers;

}

单元测试:

// 在单元测试中注入这个bean
@Autowired
private Users user;

@Test
void testUsers(){
    System.out.println(user.getName());
    System.out.println(user.getAge());
}

结果:

Mr.Zhang
38

三、YamlMapFactoryBean

通过这个factoryBean可以直接返回一个Map,而不需要使用JavaBean去接收yml读取的值

public static void main(String[] arg0){
    YamlMapFactoryBean yamlMapFactoryBean = new YamlMapFactoryBean();
    //可以加载多个yml文件
    yamlMapFactoryBean.setResources(new ClassPathResource("application.yml"));
    //通过getObject()方法获取Map对象
    Map<String, Object> map = yamlMapFactoryBean.getObject();
    System.out.println(map);
    map.keySet().forEach(item -> {
        //可以将map中的值强转为LinkedHashMap对象
        LinkedHashMap<String, Object> linkedHashMap = (LinkedHashMap<String, Object>) (map.get(item));
        System.out.println(linkedHashMap.get("tels"));
    });
}

输出:

{user={user-name=zhangsan, age=18, tels=[13479990123, 13567890987, null], score={chinese=95, english=90}, users=[{name=Mr.Zhang, age=29}, {name=Mr.Li, age=39}]}}
[13479990123, 13567890987]

四、YamlPropertiesFactoryBean

通过这个类可以直接返回Properties对象

public static void main(String[] arg0){
    YamlPropertiesFactoryBean factoryBean = new YamlPropertiesFactoryBean();
    factoryBean.setResources(new ClassPathResource("application.yml"));
    Properties properties = factoryBean.getObject();
    properties.keySet().forEach(key -> System.out.println(key + "=====" + properties.get(key)));
}

输出:

user.age=====18
user.users[0].age=====5
user.users[0].user-name=====zs
user.users[1].age=====15
user.users[1].user-name=====ls
user.score.chinese=====95
user.score.english=====90
user.tels[0]=====13479990123
user.tels[1]=====13567890987
user.user-name=====zhangsan

注意:如果读取yml时产生报错,显示的是yml文件有问题,那么很可能是因为yml文件中存在的中文造成的,那么只需要修改项目和这个文件的编码即可,首先要先将文件中的内容全部复制(如果把内容删了之后yml文件的编码修改了可能会导致撤回不了,所以要复制),然后File -> Settings -> Editor -> File Encodings打开对应控制面板,将里面所有的编码都改成UTF-8即可。

原文地址:https://www.cnblogs.com/zhangcaihua/p/14631049.html