1.配置文件
Springboot使用 一个全局的配置文件
Application.properties
Application.yml
配置文件的作用:修改Spring boot自动配置的默认值;spring boot在底层都配置好了
YAML(YAML Ain't Markup language)
YAML A Markup Language:是一个标记语言
YAML isn't Markup Language:不是一个标记语言
标记语言:
以前的配置文件daduoshi ×××.×xml文件
YAML 以数据为中心,比json、xml更适合做配置文件
YAML:配置例子
Sever
port :8081
XML:配置例子
<sever>
<port>8081</port>
</sever>
2.YAML语法
1.基本语法
k:(空格)v:表示一对键值对(空格必须有)
以空格的缩进来控制层级关系;只要是左对齐的一列数据,都是同一个层级的
Sever
port : 8081
path:/hello
属性和值也是大小写敏感;
2.值的写法
字面量:普通的值(数字,字符串,布尔):
k: v:字面直接来写 ;
字符串默认不同价单引号或者双引号;
“”;双引号:不会转移字符串里面的特殊字符;特殊字符会作为本身想表示的意思
name: "zhangsan \n lisi" ; 输出;zhangsan 换行 lisi
‘':单引号;会转义字符,特殊字符最终只是一个字符串输出
name: 'zhangsan \n lisi '; 输出;zhangsan \n lisi
对象(属性和值)(键值对):
k: v:
对象还是k:v的方式
friends:
lastName:zhangsan
age:20
行内写法:
friends: 这里有一个空格{ lastName:zhangsan,age:20}
数组(List、Set):
用短横线-值表示数组中的一个元素
pets:
cat
dog
pig (ps注意空格)
行内写法
pets:空格 [cat,dog,pig]
yml文件第一个person必须顶格写,我在报错后。复制粘贴了老师的文档,经过检查是第一个person没有顶格写
还有在SpringBoot02ConfigApplicationTests文件中缺少@RunWith是由于没有在pom.xml配置junit依赖
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
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>
1、properties配置文件在idea中默认utf-8可能会乱码
调整
2、@Value获取值和@ConfigurationProperties获取值比较
@ConfigurationProperties | @Value | |
功能 | 批量注入配置文件中的属性 | 一个个指定 |
松散绑定(松散语法) | 支持 | 不支持 |
SpEL | 不支持 | 支持 |
JSR303数据校验 | 支持 | 不支持 |
复杂类型封装 | 支持 | 不支持 |
Ps:JSR303数据校验
⽇常项⽬开发中,对于前端提交的表单,后台接⼝接收到表单数据后,为了程序的严谨性,通常后端 会加⼊业务参数的合法校验操作来避免程序的⾮技术性 bug,这⾥对于客户端提交的数据校验, SpringBoot 通过 spring-boot-starter-validation 模块包含了数据校验的⼯作。 这⾥主要介绍 Spring Boot 中对请求数据进⾏校验,相关概念如下 JSR303 :JSR303 是⼀项标准,只提供规范不提供实现,规定⼀些校验规范即校验注解,如 @Null,@NotNull,@Pattern,位于 javax.validation.constraints 包下。JSR-349 是其升级版本,添加 了⼀些新特性。 Hibernate Validation :Hibernate Validation 是对这个规范的实现,并增加了⼀些其他校验注解,如 @Email,@Length,@Range 等等。 Spring Validation :Spring Validation 对 Hibernate Validation 进⾏了⼆次封装,在 Spring MVC 模块中 添加了⾃动校验,并将校验信息封装进了特定的类中。 实现参数校验,程序必须引⼊ spring-boot-starter-validation 依赖,只是在引⼊ spring-boot-starter-web 依赖时,该模块会⾃动依赖 spring-boot-starter-validation,所以程序中引⼊ spring-boot-starter-web 会⼀ 并依赖spring-boot-starter-validation 到项⽬中. @AssertFalse 可以为null,如果不为null的话必须为false @AssertTrue 可以为null,如果不为null的话必须为true @DecimalMax 设置不能超过最⼤值 @DecimalMin 设置不能超过最⼩值 @Digits 设置必须是数字且数字整数的位数和⼩数的位数必须在指定范围内 @Future ⽇期必须在当前⽇期的未来 @Past ⽇期必须在当前⽇期的过去 @Max 最⼤不得超过此最⼤值 @Min 最⼤不得⼩于此最⼩值 @NotNull 不能为null,可以是空 @Min 最⼤不得⼩于此最⼩值 @Pattern 必须满⾜指定的正则表达式 @Size 集合、数组、map等的size()值必须在指定范围内 @Email 必须是email格式 @Length ⻓度必须在指定范围内 @NotBlank 字符串不能为null,字符串trim()后也不能等于“” @NotEmpty 不能为null,集合、数组、map等size()不能为0;字符串trim()后可以等于“” @Range 值必须在指定范围内 @URL 必须是⼀个URL
想要使用@Email数据校验需要在pom.xml中添加依赖
|
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>1.1.0.Final</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
配置文件yml还是properties他们都能获取到值;
如果说,我们只是在某个业务逻辑中需要获取一下配置文件中的某项值,使用@Value;
如果说,我们专门编写了一个javaBean来和配置文件进行映射,我们就直接使用@ConfigurationProperties;
3、配置文件注入值数据校验
@Component
@ConfigurationProperties(prefix = "person")
@Validated 校验
public class Person {
/**
* <bean class="Person">
* <property name="lastName" value="字面量/${key}从环境变量、配置文件中获取值/#{SpEL}"></property>
* <bean/>
*/
//lastName必须是邮箱格式
@Email
//@Value("${person.last-name}")
private String lastName;
//@Value("#{11*2}")
private Integer age;
//@Value("true")
private Boolean boss;
private Date birth;
private Map<String,Object> maps;
private List<Object> lists;
private Dog dog;
value是指定值
4、@PropertySource&@ImportResource&@Bean
@PropertySource:加载指定的配置文件;
/**
* 将配置文件中配置的每一个属性的值,映射到这个组件中
* @ConfigurationProperties:告诉SpringBoot将本类中的所有属性和配置文件中相关的配置进行绑定;
* prefix = "person":配置文件中哪个下面的所有属性进行一一映射
*
* 只有这个组件是容器中的组件,才能容器提供的@ConfigurationProperties功能;
* @ConfigurationProperties(prefix = "person")默认从全局配置文件中获取值;
*
*/
@PropertySource(value = {"classpath:person.properties"})
@Component
@ConfigurationProperties(prefix = "person")
//@Validated
public class Person {
实际应用过程中报错Failed to load ApplicationContext,Error creating bean with name 'defaultValidator'原来又是缺少依赖调试了一个多小时终于解决于一个bug
原来要同时添加两个依赖
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.2.0.Final</version>//于本机的maven的版本相适应
</dependency>
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>2.0.1.Final</version>
</dependency>
自己的maven包里找hibernate-validator的版本
屏幕剪辑的捕获时间: 2022/1/18 21:43
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>5.2.4.Final</version> //这个要看你的Maven依赖包的版本
</dependency>
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>2.0.1.Final</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-webflux</artifactId>
</dependency>
他用了三个依赖包,我没用最后一个也成功了。有会的老哥可以给我解释一下
所有的笔记都是跟着尚硅谷的老师敲得,加入了我自己遇到的问题