springboot yml文件语法,以及配置文件注入

38 篇文章 ¥19.90 ¥99.00
本文详细介绍了YAML语法,包括基本语法、值的写法,如字面量、对象与Map、数组的表示。同时,讨论了如何在SpringBoot中进行配置文件值的注入,通过配置文件处理器提升开发效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

YAML语法:

1、基本语法

k:(空格)v:表示一对键值对(空格必须有);

空格的缩进来控制层级关系;只要是左对齐的一列数据,都是同一个层级的

server:
    port: 8081
    path: /hello

属性和值也是大小写敏感;

2、值的写法

字面量:普通的值(数字,字符串,布尔)

​ k: v:字面直接来写;

​ 字符串默认不用加上单引号或者双引号;

​ “”:双引号;不会转义字符串里面的特殊字符;特殊字符会作为本身想表示的意思

​ name: “zhangsan \n lisi”:输出;zhangsan 换行 lisi

​ ”:单引号;会转义特殊字符,特殊字符最终只是一个普通的字符串数据

​ name: ‘zhangsan \n lisi’:输出;zhangsan \n lisi

对象、Map(属性和值)(键值对):

​ k: v:在下一行来写对象的属性和值的关系;注意缩进

​ 对象还是k: v的方式

friends:
        lastName: zhangsan
        age: 20

行内写法:

friends: {lastName: zhangsan,age: 18}
数组(List、Set):

用- 值表示数组中的一个元素

pets:
 - cat
 - dog
 - pig

行内写法

pets: [cat,dog,pig]

3、配置文件值注入

配置文件

person:
    lastName: hello
    age: 18
    boss: false
    birth: 2017/12/12
    maps: {k1: v1,k2: 12}
    lists:
      - lisi
      - zhaoliu
    dog:
      name: 小狗
      age: 12

javaBean:

/**
 * 将配置文件中配置的每一个属性的值,映射到这个组件中
 * @ConfigurationProperties:告诉SpringBoot将本类中的所有属性和配置文件中相关的配置进行绑定;
 *      prefix = "person":配置文件中哪个下面的所有属性进行一一映射
 *
 * 只有这个组件是容器中的组件,才能容器提供的@ConfigurationProperties功能;
 *
 */
@Component
@ConfigurationProperties(prefix = "person")
public class Person {

    private String lastName;
    private Integer age;
    private Boolean boss;
    private Date birth;

    private Map<String,Object> maps;
    private List<Object> lists;
    private Dog dog;

我们可以导入配置文件处理器,以后编写配置就有提示了

<!--导入配置文件处理器,配置文件进行绑定就会有提示-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>
### Spring Boot 中 YAML 文件的使用与配置 #### 1. 基本语法介绍 YAML 是一种简洁的人类可读的数据序列化标准,广泛用于配置文件。在 Spring Boot 应用程序中,`application.yml` 或 `application.properties` 可以用来存储应用程序的各种配置参数。 对于复杂数据结构如列表、数组和映射表 (Map),可以采用特定的方式进行定义: - **键值对形式**:这是最简单的表示方法,适用于基本类型的属性设置。 ```yaml server: port: 8080 ``` - **嵌套对象**:通过缩进来表达层次关系,每级缩进两个空格。 ```yaml my-app: name: MyAppName version: "1.0" ``` - **List/Array 类型**:利用连字符 `-` 来指定列表项;也可以放在同一行并用逗号分隔多个元素。 ```yaml environments: active-profiles: ["dev", "test"] servers: - host: localhost port: 9000 - host: remotehost port: 9001 ``` - **Map 类型**:可以通过冒号后面跟上一对或多对键值来创建 map 结构[^1]。 ```yaml my-node: node: key1: value1 key2: value2 ``` #### 2. 数据绑定到 Java Bean 属性 为了使上述配置生效并将这些配置自动注入到Java bean中,在实体类里声明相应的字段,并配合使用注解完成依赖注入操作。例如要获取名为 `my-node.node` 下面所有的子节点作为 Map 形式的实例变量,则可以在对应的 POJO 类内这样写: ```java @Data public class Test { @Value("#{${my-node.node}}") private Map<String, String> instanceMap; } ``` 这里需要注意的是当涉及到复杂的类型转换时可能会遇到一些问题,比如直接尝试将整个 section 映射成一个 Map 对象可能不会按预期工作,这时就需要更加细致地调整配置方式或者借助其他工具辅助实现[^2]。 #### 3. 错误处理建议 如果发现无法成功加载或解析某些配置项,应该仔细检查以下几个方面: - 确认 yaml 文件中的格式正确无误; - 查看日志输出寻找潜在异常信息; - 尝试简化配置测试是否为某个具体条目引起的问题; - 考虑升级 spring-boot 版本来获得更好的兼容性和支持特性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值