Spring Boot 配置文件

嚴華  金牌会员 | 2022-6-25 09:53:49 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 548|帖子 548|积分 1644

文章目录



配置文件的作用就是保存项目中的所有重要的数据信息以及一些通用配置
比如启动一个项目,默认情况下 Tomcat 会占用 8080 端口,但是有些时候会因为 8080 端口已经被占用了,导致启动项目失败,解决办法要么是先查到占用端口的进程,然后从任务管理器中关闭进程,要么就是就重新设置端口号,然而一般的重置端口号的过程并不方便。
但是在配置文件中只要写一句 server.port=XXXX,启动项目,就可以发现端口号已经被改成 XXXX ,方便的很
还有数据库的连接信息、第三方系统的调用密钥等信息、日志信息的配置等等
Spring Boot 常用的配置文件的格式有两种:


  • .properties
  • .yml
这两种配置文件的格式是可以同时存在于一个项目中的,如果两配置文件中有同样的配置(比如都配置端口信息),此时会以 .properties 格式配置的端口为主,其优先级会更高
加载完 .properties 文件后,就会加载 .yml 文件
一个项目中可以存在很多 properties 文件(yml 文件),名字可以随便起,但是 Spring Boot 项目启动时,只会自动加载名字为 application 的配置文件
实际业务中,一般会统一使用其中一种配置文件的格式,可以降低故障率
官网:查看更多系统配置项
一、properties 文件

在学习 .properties 文件之前,需要先装一个插件 Spring Tools,yml 文件中是有代码提示的但是 properties 文件没有(指的是社区版),安装了该插件后,就会有相应的代码提示

1.1 properties 基本语法

properties 是以键值对的形式配置的,key 和 value 之间只要"="连接
  1. key=value
复制代码
注意:等号两边不要出现空格,value后面也不要出现空格
  1. # 端口号设置
  2. server.port=9090
  3. # 数据库连接信息设置
  4. spring.datasource.url=jdbc:mysql://127.0.0.1:3306/OJSystem
  5. spring.datasource.username=root
  6. spring.datasource.password=1111
复制代码
1.2 读取配置文件

在项目中读取配置文件中的内容,可以通过 @Value 注解
该注解需要使用 "${}" 的格式进行读取
代码展示
  1. @Controller
  2. @ResponseBody
  3. @RequestMapping("/index")
  4. public class UController {
  5.     @Value("${server.port}")
  6.     private Integer port;
  7.    
  8.     @RequestMapping("/port")
  9.     public String func() {
  10.         return "port:" + port;
  11.     }
  12. }
复制代码
注意
@Value 注解中的内容如果用双引号直接包含起来,表示设置一个具体的 value 值而不是配置文件中的 key ;
只有加上 ${} 才会读取到配置信息中的 key 值(server.port),将 key 值对应的 value 值(9090)赋值给 port 变量;
结果展示

1.3 properties 缺点

在上面配置数据库的信息时,会发现有很多的代码冗余,每条配置信息前都有 spring.datasource ,可读性是比较差的
二、.yml 文件

yml 文件就很好的解决了 properties 文件的缺点,可读性高,也易于理解,还可以表达数组、对象等数据形态,而且还跨语言,除了 Java,golang、python 都可以使用该类型的配置文件
2.1 yml 基本语法

yml 是树形结构的配置文件
  1. key: value
复制代码
注意:key 和 value 之间有一个英文的冒号":"和一个空格,两者缺一不可
  1. # 端口号设置
  2. server:
  3.   port: 9191
  4. # 数据库连接信息设置
  5. spring:
  6.   datasource:
  7.     url: jdbc:mysql://127.0.0.1:3306/OJSystem
  8.     username: root
  9.     password: 1111
复制代码
通过例子,可以发现 yml 文件可以很好解决 properties 文件的代码冗余问题
通过空格缩进程度来控制层级关系,如果为同级属性,缩进应当要一样
2.2 yml 的运用

yml 支持字面值、对象、数组等数据结构,也支持它们的复合结构
2.2.1 字面值

包括字符串、布尔类型、整形(包括各种进制)、浮点型(包括科学计数法)、null等
配置信息
  1. # 字符串类型
  2. String: yml配置文件
  3. # 整形
  4. myInt: 666
  5. # null
  6. myNull:
  7.   value: ~
  8. # 浮点型
  9. myDouble.value: 1.23
复制代码
yml 文件中读取配置信息也可以使用 @Value 注解,同 properties 用法相同
代码展示
  1. @Controller
  2. @ResponseBody
  3. @RequestMapping("/index")
  4. public class UController {
  5.     @Value("${String}")
  6.     private String myString;
  7.     @Value("${myInt}")
  8.     private Integer myInt;
  9.     @Value("${myDouble.value}")
  10.     private Double myDouble;
  11.     @Value("${myNull.value}")
  12.     private Object myNull;
  13.     @RequestMapping("value")
  14.     public String func1() {
  15.         String res = "String: " + myString
  16.                 + "----" + "myInt: " + myInt
  17.                 + "----" + "myNull.value: " + myNull
  18.                 + "----" + "myDouble.value: " + myDouble;
  19.         return res;
  20.     }
  21. }
复制代码
结果展示

注意:yml 中的 null 不是指值为 null ,而是指什么都没有的意思,因此打印出来内容是空的
关于字符的特殊说明
在 yml 中如果字符串使用了双引号进行包裹,那么写了特殊字符是不会进行转义的,就会按照特殊字符的方式进行处理,比如 \n 就会被当成换行符进行处理
如果字符串添加的是单引号或者什么都没有添加,就会将特殊字符进行转义,输入的是什么输出的就是什么,特殊字符最终只是一个普通的字符串数据
配置文件
  1. myString:
  2.   value1: Hello \n world
  3.   value2: 'Hello \n world'
  4.   value3: "Hello \n world"
复制代码
代码展示
  1. @Value("${myString.value1}")
  2. private String myString1;
  3. @Value("${myString.value2}")
  4. private String myString2;
  5. @Value("${myString.value3}")
  6. private String myString3;
  7. @RequestMapping("/myString")
  8. public void func2() {
  9.     System.out.println("value1: " + myString1);
  10.     System.out.println("value2: " + myString2);
  11.     System.out.println("value3: " + myString3);
  12. }
复制代码
结果显示

2.2.2 对象

yml 中可以配置对象,这是 properties 文件中所没有的
配置文件
  1. # 方式一
  2. article:
  3.   id: 1
  4.   name: 人与自然
  5.   content: 内容简介
  6. # 方式二
  7. article1: { id: 2,name: Java发展史,content: 对Java的简介 }
复制代码
注意:无论方式一还是方式二都需要在 key 和 value 间加上英文冒号以及一个空格,方式二创建对象的方式适合于属性较少时,方式一在属性较多时会更加的直观
代码展示
想要获取到配置文件中对象的信息,可以通过之前的 @Value 注解的方式,但是这样的话,对象有多少个属性,就会需要写多少个 @Value ,会非常的麻烦
所以,可以通过其他方式将对象中的内容一下子读取到某个类中,然后通过注入的方式获取到类中的信息
首先,创建一个 Article 类
通过 @ConfigurationProperties 注解来指定 Spring Boot 启动时需要将配置文件中的哪个对象赋值到该类上,其中 prefix = 可以省略
需要注意的是一定要提供 get/set 方法,尤其是 set 方法,如果不提供,项目启动后没有办法将配置文件中对应对象的属性赋值进来,就会报错。不提供 get 方法虽然不会报错,但是没有办法通过方法获取对象的某个属性了
属性名需要与配置文件中的属性名一一对应,否则获取的时候就会找不到对应的属性名,结果为默认值
  1. @Component
  2. @ConfigurationProperties(prefix = "article")
  3. public class Article {
  4.     private int id;
  5.     private String name;
  6.     private String content;
  7.     public int getId() { return id; }
  8.     public void setId(int id) { this.id = id; }
  9.    
  10.     public String getName() { return name; }
  11.     public void setName(String name) { this.name = name; }
  12.    
  13.     public String getContent() { return content; }
  14.     public void setContent(String content) { this.content = content; }
  15.     @Override
  16.     public String toString() {
  17.         return "Article{" +
  18.                 "id=" + id +
  19.                 ", name='" + name + '\'' +
  20.                 ", content='" + content + '\'' +
  21.                 '}';
  22.     }
  23. }
复制代码
然后,进行依赖的注入
需要使用 @Autowired 注解或者 @Resource 注解将 Article 类注入到依赖它的类中,这里使用的前者注解。注入方法这里使用的是属性注入
  1. @Controller
  2. @ResponseBody
  3. public class ArticleController {
  4.     @Autowired
  5.     private Article article;
  6.     @RequestMapping("/article")
  7.     public void func() {
  8.         System.out.println(article);
  9.     }
  10. }
复制代码
结果展示

2.2.3 数组

配置文件
  1. # 方法一
  2. book-list:
  3.     books:
  4.       - Java书
  5.       - Python书
  6.       - C++书
  7. # 方法二
  8. booklist1: { books: [人与自然,美人鱼] }
复制代码
在":" 和"-"后面都需要添加空格
拿方法一的案例来说,就相当于说有一个 Key 值为 book-list,key 值下面有一个 books 属性,该属性里面存储了三个信息:Java书、Python书、C++书
需要注意的是方法一中的命名方式,由于 SpringBoot 2.X 版本对配置文件中的命名规范有强制性的要求,不允许使用驼峰形式(比如bookList),需要按照提示说的那样使用 - 代替
代码显示
首先,创建一个 BookList 类
同样可以通过 @ConfigurationProperties 注解来指定 Spring Boot 启动时需要将配置文件中的哪个对象赋值到该类上
属性名 books 需要和配置文件中 key 为 book-list 的 value 中的属性名相对应
同样也需要提供 get/set 方法,这里使用了 @Data 注解。该注解来源于创建项目时引入的 lombok 依赖,加上该注解,就可以提供 get/set 方法、 toString 方法…
  1. @Component
  2. @ConfigurationProperties(prefix = "book-list")
  3. @Data
  4. public class BooKList {
  5.     private List<String> books;
  6. }
复制代码

然后,进行依赖的注入
  1. @Controller
  2. @ResponseBody
  3. public class ListController {
  4.     @Autowired
  5.     private BooKList booKList;
  6.     @RequestMapping("/list")
  7.     public void getBooks() {
  8.         System.out.println(booKList.getBooks());
  9.     }
  10. }
复制代码
结果显示

三、properties 和 yml 区别总结



  • 语法格式

    • properties :以 key=value 的键值对形式配置的配置文件,其中 key 是以 “.” 进行分割的
    • yml :使用类似 json 格式的树形配置方式进行配置,使用缩进来控制层级关系,key 和 value 之间使用冒号和一个空格隔开,皆不可省略

  • 冗余问题

    • properties :是一种默认的,早期的配置文件格式,配置存在数据的冗余
    • yml :很好的解决了数据冗余现象,可读性更高,写法更简洁明了

  • 通用性

    • properties :只是作为 Java 语言的配置文件
    • yml :通用性更好,支持多种语言,Java、Go、Python…,比如做云计算使用 Go 和 Java 的时候,可以通过配置中心使用同一份配置

  • 数据类型

    • properties :只支持键值对数据
    • yml :支持列表,对象,标量等等数据类型

完~~~

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

嚴華

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表