SpingBoot yml语法及测试总结yml文件常用的五种方式

本文介绍了SpringBoot项目中YML配置文件的使用,包括初始化项目、application.yml与application.properties的对比、YML基本语法,并通过实例展示了如何配置书目信息,涉及键值对、列表、映射等数据结构。同时提供了配置类和测试类的代码示例,详细解释了配置的读取与使用。

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

引言

今天在开发过程中用到了application.yml文件需要配置一些值,略感自己在此方面没有全面系统的使用总结过,因此使用IDEA创建好SpringBoot项目,来测试总结在yml文件中经常用到的几种类型

项目介绍

初始化SpringBoot项目

依赖文件:pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.6.7</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.zhou</groupId>
    <artifactId>springboot-setting</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>springboot-setting</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

这里的application.yml为手动新建,作为和application.properties的一个对比
在这里插入图片描述

application.properties介绍

在这里插入图片描述
看到启动日志中打印出来的端口号是8081端口号,在默认加载配置的时候使用的是application.properties配置文件。但是在项目开发时往往不使用这种方式,而是使用yml文件的方式。因此需要删除默认的配置文件,建立application.yml文件

yml配置文件基本语法

  1. YML基本语法
    k:v :表示键值对(这里注意一点就是在键和值之间有一个空格),以空格的缩进来控制层级关系
bookconfig: #这里的bookconfig就是title的一个父级
  title: 三体2:黑暗森林
  1. 字面量
    普通的值(日期,浮点型,数字,字符串,布尔)
  title: 三体2:黑暗森林
  pages: 350
  price: 98.5
  award: true  #是否获奖
  publishTime: 2019/03/09
  1. List,Set,Array的写法
  tagList: #用- 值表示集合或数组中的一个元素
    - 科幻
    - 文学
    - 物理
  tagArray: [雨果奖,银河奖,星云奖] #行内写法
  1. Map的写法
 rolesMap: {role1: 罗辑,role2: 章北海,role3: 托马斯维德}
 otherRolesMap:
    "role4": 史强
    "role5": 叶文洁
    "role7": 丁仪
  1. 对象的两种写法
 seriesBook: #空格缩进写法
    serieTitle: 《中国科幻基石丛书》
    seriesNo : 丛书号
    seriesNum: 3
 seriesBook: {serieTitle: 《中国科幻基石丛书》,seriesNo : 丛书号,seriesNum: 3} #行内写法

实际操作测试

在这里插入图片描述
这里以书目信息为配置示例:

application.yml

server:
  port: 8083

bookconfig:
  title: 三体2:黑暗森林
  pages: 350
  price: 98.5
  award: true  #是否获奖
  publishTime: 2019/03/09
  tagList:
    - 科幻
    - 文学
    - 物理
  #这里的rolesMap与otherROlesMap的效果一致,只是两种不同的写法
  rolesMap: {role1: 罗辑,role2: 章北海,role3: 托马斯维德}
  otherRolesMap:
    "role4": 史强
    "role5": 叶文洁
    "role7": 丁仪
  #丛书配置的对象
  seriesBook:
    serieTitle: 《中国科幻基石丛书》
    seriesNo : 丛书号
    seriesNum: 3

对应的配置类:
BookConfig.java

package com.zhou.config;

import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

import java.util.Date;
import java.util.HashMap;
import java.util.List;

/**
 * @author zhouquan
 * @description 配置类
 * @date 2022-05-10 17:06
 **/

//prefixe 表示配置文件中的哪个下面的所有属性进行映射。注意:这里的prefix命名必须小写!否则会提示prefix must be in canonical form less...
@ConfigurationProperties(prefix = "bookconfig")
@Data
@Component  //@Component注解表示被加上这个注解的类成为spring容器中的一个组件
public class BookConfig {

    private String title;

    private Integer pages;

    private Double price;

    private Boolean award;

    private Date publishTime;

    private List<String> tagList;

    private HashMap<String, String> rolesMap;

    private HashMap<String, String> otherRolesMap;

    private SeriesBook seriesBook;

}

丛书对象类:
SeriesBook.java

package com.zhou.config;

import lombok.Data;
import org.springframework.stereotype.Component;

/**
 * @author zhouquan
 * @description 对象类
 * @date 2022-05-10 17:27
 **/
@Component
@Data
public class SeriesBook {

    private String seriesTitle;

    private String seriesNo;

    private Integer seriesNum;

}

测试类:
SpringbootSettingApplicationTests.java

package com.zhou;

import com.zhou.config.BookConfig;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
class SpringbootSettingApplicationTests {

    @Autowired
    BookConfig bookConfig;

    @Test
    void contextLoads() {
        System.out.println(bookConfig.toString());
    }

}

输出结果:

BookConfig(title=三体2:黑暗森林, pages=350, price=98.5, award=true, publishTime=Sat Mar 09 00:00:00 CST 2019, 
tagList=[科幻, 文学, 物理], 
rolesMap={role1=罗辑, role2=章北海, role3=托马斯维德}, 
otherRolesMap={role4=史强, role5=叶文洁, role7=丁仪}, 
seriesBook=SeriesBook(serieTitle=《中国科幻基石丛书》, seriesNo=丛书号, seriesNum=3))

<think>嗯,用户想知道如何在Spring Boot项目中创建和使用yml配置文件。首先,我需要回忆一下相关的知识。记得Spring Boot支持两种配置文件格式:properties和yml。YAML文件的结构更清晰,适合复杂配置。那创建yml文件应该是在resources目录下新建一个application.yml文件吧?对的,用户需要确认目录结构正确,比如src/main/resources下。 接下来,使用yml文件的话,需要遵循正确的语法,比如用缩进表示层级,冒号后面加空格。比如配置server.port应该是: server: port: 8080 对吧?然后,在代码中可以通过@Value注解或者@ConfigurationProperties来读取配置值。可能需要举例说明这两种方式,这样用户更清楚。 然后,用户可能还会想知道多环境配置,比如application-dev.yml,application-prod.yml。这时候需要在主application.yml里通过spring.profiles.active来激活不同的环境配置。记得要提到不同环境的加载顺序,比如默认的application.yml会被覆盖,如果有指定profile的话。 另外,用户提供的引用里有提到在yml中读取pom.xml的properties属性。这个可能需要用到Maven资源过滤功能,在pom.xml里配置资源过滤,然后在application.yml中使用${property}占位符。不过这部分可能需要详细步骤,比如在pom中开启过滤,设置属性,然后在yml里引用。 还要注意YAML的语法容易出错,比如缩进不对或者冒号后面没空格,这时候配置可能不生效。需要提醒用户检查这些细节。还有配置的优先级,比如外部配置文件、命令行参数等的影响,但用户的问题可能主要在于创建和使用,这部分可以简要提及。 最后,用户可能需要常见问题的解决方法,比如配置未生效时如何排查,比如检查文件位置、语法错误、属性名称是否正确等。总结一下,步骤应该是创建文件、编写配置、读取配置,以及多环境配置的处理。确保回答结构清晰,分步骤说明,并给出示例代码,这样用户能一步步跟着操作。</think>### 如何在 Spring Boot 中创建和使用 YML 文件 #### 1. **创建 YML 文件** 在 Spring Boot 项目中,默认的配置文件是 `application.properties`,但可以通过以下步骤创建 YML 文件- **步骤 1**:在项目的 `src/main/resources` 目录下新建文件,命名为 `application.yml`。 - **步骤 2**:确保文件层级结构与 Spring Boot 的配置要求一致。YML 文件通过缩进表示层级关系,语法比 `.properties` 更简洁直观。 #### 2. **编写 YML 配置** YML 文件的基本语法示例: ```yaml server: port: 8080 spring: datasource: url: jdbc:mysql://localhost:3306/test username: root password: 123456 ``` - **说明**:`server.port` 设置服务端口,`spring.datasource` 定义数据库连接信息[^2]。 #### 3. **读取 YML 配置** Spring Boot 支持通过两种方式读取配置: - **方式 1**:使用 `@Value` 注解直接注入值: ```java @Value("${server.port}") private int port; ``` - **方式 2**:使用 `@ConfigurationProperties` 绑定配置类: ```java @Configuration @ConfigurationProperties(prefix = "spring.datasource") public class DataSourceConfig { private String url; private String username; private String password; // getter/setter 省略 } ``` #### 4. **多环境配置** 通过 YML 文件实现多环境配置(如开发、测试、生产): - **步骤 1**:创建多个配置文件,例如 `application-dev.yml`(开发环境)、`application-prod.yml`(生产环境)。 - **步骤 2**:在主配置文件 `application.yml` 中激活指定环境: ```yaml spring: profiles: active: dev ``` - **说明**:Spring Boot 会按优先级加载配置,命令行参数 > 当前激活的配置文件 > 默认配置[^3]。 #### 5. **从 Maven POM 读取属性** 若需在 YML 中读取 Maven 的 `pom.xml` 属性(如版本号): - **步骤 1**:在 `pom.xml` 中定义属性: ```xml <properties> <project.version>1.0.0</project.version> </properties> ``` - **步骤 2**:在 `application.yml` 中使用占位符: ```yaml app: version: @project.version@ ``` - **说明**:需在 `pom.xml` 中启用资源过滤(`<filtering>true</filtering>`)[^1]。 #### 6. **常见问题** - **配置未生效**:检查文件路径是否为 `src/main/resources`,或通过 `spring.config.location` 指定外部文件路径[^4]。 - **语法错误**:YML 严格依赖缩进和冒号后的空格,建议使用 IDE 的语法检查工具。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

徐州蔡徐坤

又要到饭了兄弟们

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值