YAML教程

Spring Boot 提供了大量的自动配置,极大地简化了 spring 应用的开发过程,当用户创建了一个 Spring Boot 项目后,即使不进行任何配置,该项目也能顺利的运行起来。当然,用户也可以根据自身的需要使用配置文件修改 Spring Boot 的默认设置。

Spring Boot 默认使用以下 2 种全局的配置文件,其文件名是固定的。

  • application.properties
  • application.yml

其中,application.yml 是一种使用 YAML 语言编写的文件,它与 application.properties 一样,可以在 Spring Boot 启动时被自动读取,修改 Spring Boot 自动配置的默认值。

本篇文章将详细介绍 YAML 语言的语法及使用。

YAML 简介

YAML 全称 YAML Ain't Markup Language ,它是一种以数据为中心的标记语言,比 XML 和 JSON 更适合作为配置文件。

想要使用 YAML 作为属性配置文件(以 .yml 或 .yaml 结尾),需要将 SnakeYAML 库添加到 classpath 下,Spring Boot 中的 spring-boot-starter-web 或 spring-boot-starter 都对 SnakeYAML 库做了集成,只要项目中引用了这两个 Starter 中的任何一个,Spring Boot 会自动添加 SnakeYAML 库到 classpath 下。

下面是一个简单的 application.yml 属性配置文件。

server:
    port: 8081

YAML 语法

YAML 的语法如下:

  • 使用缩进表示层级关系
  • 缩进时不允许使用 Tab 键,只允许使用空格
  • 缩进的空格数不重要,但同级元素必须左侧对齐
  • 大小写敏感

例如:

spring:
    profiles: dev

    datasource:
        url: jdbc:mysql://127.0.0.1/test
        username: root
        password: root
        driver-class-name: com.mysql.jdbc.Driver

YAML 常用写法

YAML 支持以下三种数据结构:

  • 对象:键值对的集合
  • 数组:一组按次序排列的值
  • 字面量:单个的、不可拆分的值

YAML 字面量写法

字面量是指单个的,不可拆分的值,例如:数字、字符串、布尔值、以及日期等。

在 YAML 中,使用 “key:[空格]value” 的形式表示一对键值对(空格不能省略),如 username: root

字面量直接写在键值对的 “value” 中即可,且默认情况下字符串是不需要使用单引号或双引号的。

name: xiaozhao

若字符串使用单引号,则会转义特殊字符。

name: 'xiao \n zhao'

输出结果为:

xiao \n zhao

若字符串使用双引号,则不会转义特殊字符,特殊字符会输出为其本身想表达的含义

name: "xiao \n zhao"

输出结果为:

xiao
zhao

YAML 对象写法

在 YAML 中,对象可能包含多个属性,每一个属性都是一对键值对。

YAML 为对象提供了 2 种写法:

普通写法,使用缩进表示对象与属性的层级关系

website:
    name: baidu
    url: www.baidu.com

行内写法:

website: {name: baidu, url: www.baidu.com}

YAML 数组写法

YAML 使用 “-” 表示数组中的元素,普通写法如下:

pets:
  -dog
  -cat
  -pig

行内写法

pets: [dog,cat,pig]

复合结构

以上三种数据结构可以任意组合使用,以实现不同的用户需求,例如:

person:
  name: xiaozhao
  age: 25
  pets:
    -dog
    -cat
    -pig
  car:
    name: QQ
  child:
    name: moyu
    age: 2

YAML 组织结构

一个 YAML 文件可以由一个或多个文档组成,文档之间使用 “---” 作为分隔符,且各个文档相互独立,互不干扰。如果 YAML 文件只包含一个文档,则 “---” 分隔符可以省略。

---
website:
  name: baidu
  url: www.baidu.com
---
website: {name: baidu,url: www.baidu.com}

pets:
  -dog
  -cat
  -pig

---
pets: [dog,cat,pig]

name: "zhangsan \n lisi"

---

name: 'zhangsan \n' lisi'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值