热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

yamlspringboot

狂神哔哩哔哩视频地址:https:space.bilibili.com952564495、yaml配置配置文件SpringBoot使用一个全局的配置文件,配置文件

狂神哔哩哔哩视频地址:https://space.bilibili.com/95256449


5、yaml 配置

配置文件

SpringBoot使用一个全局的配置文件 , 配置文件名称是固定的

  • application.properties
    • 语法结构 :key=value
  • application.yml
    • 语法结构 :key:空格 value

**配置文件的作用 :**修改SpringBoot自动配置的默认值,因为SpringBoot在底层都给我们自动配置好了;

比如我们可以在配置文件中修改Tomcat 默认启动的端口号!测试一下!

server.port=8081

yaml概述

YAML是 “YAML Ain’t a Markup Language” (YAML不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:“Yet Another Markup Language”(仍是一种标记语言)

这种语言以数据作为中心,而不是以标记语言为重点!

以前的配置文件,大多数都是使用xml来配置;比如一个简单的端口配置,我们来对比下yaml和xml

传统xml配置:

<server><port>8081<port>
server>

yaml配置&#xff1a;

server&#xff1a;prot: 8080

yaml基础语法

说明&#xff1a;语法要求严格&#xff01;

1、空格不能省略

2、以缩进来控制层级关系&#xff0c;只要是左边对齐的一列数据都是同一个层级的。

3、属性和值的大小写都是十分敏感的。

字面量&#xff1a;普通的值 [ 数字&#xff0c;布尔值&#xff0c;字符串 ]

字面量直接写在后面就可以 &#xff0c; 字符串默认不用加上双引号或者单引号&#xff1b;

k: v

注意&#xff1a;

  • “ ” 双引号&#xff0c;不会转义字符串里面的特殊字符 &#xff0c; 特殊字符会作为本身想表示的意思&#xff1b;

    比如 &#xff1a;name: “kuang \n shen” 输出 &#xff1a;kuang 换行 shen

  • ‘’ 单引号&#xff0c;会转义特殊字符 &#xff0c; 特殊字符最终会变成和普通字符一样输出

    比如 &#xff1a;name: ‘kuang \n shen’ 输出 &#xff1a;kuang \n shen

对象、Map&#xff08;键值对&#xff09;

#对象、Map格式
k: v1:v2:

在下一行来写对象的属性和值得关系&#xff0c;注意缩进&#xff1b;比如&#xff1a;

student:name: qinjiangage: 3

行内写法

student: {name: qinjiang,age: 3}

数组&#xff08; List、set &#xff09;

用 - 值表示数组中的一个元素,比如&#xff1a;

pets:- cat- dog- pig

行内写法

pets: [cat,dog,pig]

修改SpringBoot的默认端口号

配置文件中添加&#xff0c;端口号的参数&#xff0c;就可以切换端口&#xff1b;

server:port: 8082

注入配置文件

yaml文件更强大的地方在于&#xff0c;他可以给我们的实体类直接注入匹配值&#xff01;

yaml注入配置文件

1、在springboot项目中的resources目录下新建一个文件 application.yml

2、编写一个实体类 Dog&#xff1b;

package com.kuang.springboot.pojo;&#64;Component //注册bean到容器中
public class Dog {private String name;private Integer age;//有参无参构造、get、set方法、toString()方法
}

3、思考&#xff0c;我们原来是如何给bean注入属性值的&#xff01;&#64;Value&#xff0c;给狗狗类测试一下&#xff1a;

&#64;Component //注册bean
public class Dog {&#64;Value("阿黄")private String name;&#64;Value("18")private Integer age;
}

4、在SpringBoot的测试类下注入狗狗输出一下&#xff1b;

&#64;SpringBootTest
class DemoApplicationTests {&#64;Autowired //将狗狗自动注入进来Dog dog;&#64;Testpublic void contextLoads() {System.out.println(dog); //打印看下狗狗对象}}

结果成功输出&#xff0c;&#64;Value注入成功&#xff0c;这是我们原来的办法对吧。

img

5、我们在编写一个复杂一点的实体类&#xff1a;Person 类

&#64;Component //注册bean到容器中
public class Person {private String name;private Integer age;private Boolean happy;private Date birth;private Map<String,Object> maps;private List<Object> lists;private Dog dog;//有参无参构造、get、set方法、toString()方法
}

6、我们来使用yaml配置的方式进行注入&#xff0c;大家写的时候注意区别和优势&#xff0c;我们编写一个yaml配置&#xff01;

person:name: qinjiangage: 3happy: falsebirth: 2000/01/01maps: {k1: v1,k2: v2}lists:- code- girl- musicdog:name: 旺财age: 1

7、我们刚才已经把person这个对象的所有值都写好了&#xff0c;我们现在来注入到我们的类中&#xff01;

/*
&#64;ConfigurationProperties作用&#xff1a;
将配置文件中配置的每一个属性的值&#xff0c;映射到这个组件中&#xff1b;
告诉SpringBoot将本类中的所有属性和配置文件中相关的配置进行绑定
参数 prefix &#61; “person” : 将配置文件中的person下面的所有属性一一对应
*/

&#64;Component //注册bean
&#64;ConfigurationProperties(prefix &#61; "person")
public class Person {private String name;private Integer age;private Boolean happy;private Date birth;private Map<String,Object> maps;private List<Object> lists;private Dog dog;
}

8、IDEA 提示&#xff0c;springboot配置注解处理器没有找到&#xff0c;让我们看文档&#xff0c;我们可以查看文档&#xff0c;找到一个依赖&#xff01;

img

img


<dependency><groupId>org.springframework.bootgroupId><artifactId>spring-boot-configuration-processorartifactId><optional>trueoptional>
dependency>

9、确认以上配置都OK之后&#xff0c;我们去测试类中测试一下&#xff1a;

&#64;SpringBootTest
class DemoApplicationTests {&#64;AutowiredPerson person; //将person自动注入进来&#64;Testpublic void contextLoads() {System.out.println(person); //打印person信息}}

结果&#xff1a;所有值全部注入成功&#xff01;

img

yaml配置注入到实体类完全OK&#xff01;

课堂测试&#xff1a;

1、将配置文件的key 值 和 属性的值设置为不一样&#xff0c;则结果输出为null&#xff0c;注入失败

2、在配置一个person2&#xff0c;然后将 &#64;ConfigurationProperties(prefix &#61; “person2”) 指向我们的person2&#xff1b;

加载指定的配置文件

**&#64;PropertySource &#xff1a;**加载指定的配置文件&#xff1b;

&#64;configurationProperties&#xff1a;默认从全局配置文件中获取值&#xff1b;

1、我们去在resources目录下新建一个person.properties文件

name&#61;kuangshen

2、然后在我们的代码中指定加载person.properties文件

&#64;PropertySource(value &#61; "classpath:person.properties")
&#64;Component //注册bean
public class Person {&#64;Value("${name}")private String name;......
}

3、再次输出测试一下&#xff1a;指定配置文件绑定成功&#xff01;

img

配置文件占位符

配置文件还可以编写占位符生成随机数

person:name: qinjiang${random.uuid} # 随机uuidage: ${random.int} # 随机inthappy: falsebirth: 2000/01/01maps: {k1: v1,k2: v2}lists:- code- girl- musicdog:name: ${person.hello:other}_旺财age: 1

回顾properties配置

我们上面采用的yaml方法都是最简单的方式&#xff0c;开发中最常用的&#xff1b;也是springboot所推荐的&#xff01;那我们来唠唠其他的实现方式&#xff0c;道理都是相同的&#xff1b;写还是那样写&#xff1b;配置文件除了yml还有我们之前常用的properties &#xff0c; 我们没有讲&#xff0c;我们来唠唠&#xff01;

【注意】properties配置文件在写中文的时候&#xff0c;会有乱码 &#xff0c; 我们需要去IDEA中设置编码格式为UTF-8&#xff1b;

settings–>FileEncodings 中配置&#xff1b;

img

测试步骤&#xff1a;

1、新建一个实体类User

&#64;Component //注册bean
public class User {private String name;private int age;private String sex;
}

2、编辑配置文件 user.properties

user1.name&#61;kuangshen
user1.age&#61;18
user1.sex&#61;男

3、我们在User类上使用&#64;Value来进行注入&#xff01;

&#64;Component //注册bean
&#64;PropertySource(value &#61; "classpath:user.properties")
public class User {//直接使用&#64;value&#64;Value("${user.name}") //从配置文件中取值private String name;&#64;Value("#{9*2}") // #{SPEL} Spring表达式private int age;&#64;Value("男") // 字面量private String sex;
}

4、Springboot测试

&#64;SpringBootTest
class DemoApplicationTests {&#64;AutowiredUser user;&#64;Testpublic void contextLoads() {System.out.println(user);}}

结果正常输出&#xff1a;

img

对比小结

&#64;Value这个使用起来并不友好&#xff01;我们需要为每个属性单独注解赋值&#xff0c;比较麻烦&#xff1b;我们来看个功能对比图

img

1、&#64;ConfigurationProperties只需要写一次即可 &#xff0c; &#64;Value则需要每个字段都添加

2、松散绑定&#xff1a;这个什么意思呢? 比如我的yml中写的last-name&#xff0c;这个和lastName是一样的&#xff0c; - 后面跟着的字母默认是大写的。这就是松散绑定。可以测试一下

3、JSR303数据校验 &#xff0c; 这个就是我们可以在字段是增加一层过滤器验证 &#xff0c; 可以保证数据的合法性

4、复杂类型封装&#xff0c;yml中可以封装对象 &#xff0c; 使用value就不支持

结论&#xff1a;

配置yml和配置properties都可以获取到值 &#xff0c; 强烈推荐 yml&#xff1b;

如果我们在某个业务中&#xff0c;只需要获取配置文件中的某个值&#xff0c;可以使用一下 &#64;value&#xff1b;

如果说&#xff0c;我们专门编写了一个JavaBean来和配置文件进行一一映射&#xff0c;就直接&#64;configurationProperties&#xff0c;不要犹豫&#xff01;


推荐阅读
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文详细介绍了PHP中与URL处理相关的三个函数:http_build_query、parse_str和查询字符串的解析。通过示例和语法说明,讲解了这些函数的使用方法和作用,帮助读者更好地理解和应用。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 如何去除Win7快捷方式的箭头
    本文介绍了如何去除Win7快捷方式的箭头的方法,通过生成一个透明的ico图标并将其命名为Empty.ico,将图标复制到windows目录下,并导入注册表,即可去除箭头。这样做可以改善默认快捷方式的外观,提升桌面整洁度。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 原文地址:https:www.cnblogs.combaoyipSpringBoot_YML.html1.在springboot中,有两种配置文件,一种 ... [详细]
  • 本文介绍了PhysioNet网站提供的生理信号处理工具箱WFDB Toolbox for Matlab的安装和使用方法。通过下载并添加到Matlab路径中或直接在Matlab中输入相关内容,即可完成安装。该工具箱提供了一系列函数,可以方便地处理生理信号数据。详细的安装和使用方法可以参考本文内容。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
author-avatar
鱼儿没有水会死_543
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有