读取 YAML 配置文件

本文介绍了YAML的基本语法,包括大小写敏感、缩进规则和注释方式。强调了对象、数组和纯量的概念。通过实例展示了在Spring Boot中如何配置和取值,提到了Person类的配置以及新增配置类的方式。还详细说明了YAML中的文本处理,包括单引号和双引号的区别,以及大文本的表示。最后,文章提及了多文档合并的特性。
摘要由CSDN通过智能技术生成

基本语法

  • 大小写敏感
  • 使用缩进表示层级关系,k: v,使用空格分割k,v
  • 缩进时不允许使用Tab键,只允许使用空格。换行
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
  • # 表示注释,从这个字符一直到行尾,都会被解析器忽略。

支持的写法:

  • 对象键值对的集合,如:映射(map)/ 哈希(hash) / 字典(dictionary)
  • 数组:一组按次序排列的值,如:序列(sequence) / 列表(list)
  • 纯量:单个的、不可再分的值,如:字符串、数字、bool、日期

实例

@Component //加到类路径自动扫描 
@ConfigurationProperties(prefix = "person") //和配置文件person前缀的所有配置进行绑定
@Data //自动生成JavaBean属性的getter/setter
//@NoArgsConstructor //自动生成无参构造器
//@AllArgsConstructor //自动生成全参构造器
public class Person {
    private String name;
    private Integer age;
    private Date birthDay;
    private Boolean like;
    private Child child; //嵌套对象
    private List<Dog> dogs; //数组(里面是对象)
    private Map<String,Cat> cats; //表示Map
    private static String description; // 静态变量;多行文本
    
    public static String getDescription() {
        return description;
    }

    /**
     * 此方法修改的是静态变量description,注意不能是静态方法。
     */
    public void setDescription(String description) {
        Person.description = description;
    }
}

@Data
public class Dog {
    private String name;
    private Integer age;
}

@Data
public class Child {
    private String name;
    private Integer age;
    private Date birthDay;
    private List<String> text; //数组
}

@Data
public class Cat {
    private String name;
    private Integer age;
}
  • 除了使用 @Component 加到类路径自动扫描,还可以使用 @Configuration + @Bean 方式。

    Peson类去除

    @Component //加到类路径自动扫描 
    @ConfigurationProperties(prefix = "person") //和配置文件person前缀的所有配置进行绑定
    

    新增配置类

    @Configuration // 代表这个类是一个配置类,可理解为用spring的时候xml里面的<beans>标签
    public class AppConfig {
    
        @Bean // 用来定义一个bean,可以指定初始、销毁方法,及bean范围等,可理解为用spring的时候xml里面的<bean>标签
        @ConfigurationProperties(prefix = "person")
        Person person() {
            return new Person();
        }
        
    }
    

yml

person:
  name: 张三
  age: 18
  # birthDay: 2010/10/10 12:12:12 推荐写为 birth-day
  birth-day: 2010/10/10 12:12:12
  like: true
  # private Child child; //嵌套对象
  child:
    name: 李四
    age: 20
    birth-day: 2018/10/10
    # private List<String> text; //数组
    text: ["abc","def"]
  # private List<Dog> dogs; //数组(里面是对象)
  dogs:
    - name: 小黑
      age: 3
    - name: 小白
      age: 2
  # private Map<String,Cat> cats; //表示Map
  cats:
    c1:
      name: 小蓝
      age: 3
    c2: {name: 小绿,age: 2} #对象也可用{}表示
  # | 保留文本格式,换行符正确显示
#   description: |
#     这是一个多行字符串的示例,
#     在这个示例中,
#     换行符和空格都会被保留。
  # > 折叠换行符,显示为一行
  description: >
    这是一个多行字符串的示例,
    在这个示例中,
    换行符和空格不会被保留。

细节

  • birthDay 推荐写为 birth-day
  • 文本
    • 单引号不会转义【\n 则为普通字符串显示】
    • 双引号会转义【\n会显示为换行符
  • 大文本
    • |开头,大文本写在下层,保留文本格式换行符正确显示
    • >开头,大文本写在下层,折叠换行符
  • 多文档合并
    • 使用--可以把多个yaml文档合并在一个文档中,每个文档区依然认为内容独立

取值

// 获取静态变量
Person.getDescription()
// 获取非静态变量
@Resource
private Person person;

person.getName()
  • 8
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值