SpringBoot配置文件

前言🍭

❤️❤️❤️SSM专栏更新中,各位大佬觉得写得不错,支持一下,感谢了!❤️❤️❤️

Spring + Spring MVC + MyBatis_冷兮雪的博客-CSDN博客

 前篇我们说完了SpringBoot的创建与使用,这篇讲SpringBoot的配置文件,那么SpringBoot的配置文件有什么用呢?那就到了这篇文章的主题——配置文件。

一、为什么学配置文件&配置文件的作用🍭

整个项目中所有重要的数据都是在配置文件中配置的,比如:
  • 数据库的连接信息(包含用户名和密码的设置)【最常用】;
  • 项目的启动端口;
  • 第三方系统的调用秘钥等信息;
  • 用于发现和定位问题的普通日志和异常日志等。

想象一下如果没有配置信息,那么 Spring Boot 项目就不能连接和操作数据库,甚至是不能保存可以用于排查问题的关键日志,所以配置文件的作用是非常重要的。

二、配置文件的格式🍭

Spring Boot 配置文件主要分为以下两种格式:

  • .properties
  • .yml

为什么要学两种配置文件?

因为现在有的企业用.properties有的使用.yml

或者图标是这样:

这就好像连锁店里面的统一服装一样,有两种不同的款式,properties 类型的配置文件就属于老款“服饰”,也是创建 Spring Boot 项目时默认的文件格式(主要是由于仓库里还有库存),而 yml 属于新版 款式,如果用户了解情况直接指定要新款服饰,那么就直接发给他。

特殊说明:🍓

  1. 理论上讲 properties 可以和 yml 一起存在于一个项目当中,当 properties 和 yml 一起存在一个项目中时,如果配置文件中出现了同样的配置,比如 properties 和 yml 中都配置了“server.port”, 那么这个时候会以 properties 中的配置为主,也就是 .properties 配置文件的优先级最高,但加载 完 .properties 文件之后,也会加载 .yml 文件的配置信息
  2. 虽然理论上来讲 .properties 可以和 .yml 共存,但实际的业务当中,我们通常会采取一种统一的配 置文件格式,这样可以更好的维护(降低故障率)。这就好像连锁店的服饰一样,不管是老款的服 装还是新款的服装,一定要统一了才好看。

三、properties 配置文件🍭

properties 配置文件是最早期的配置文件格式,也是创建 Spring Boot 项目默认的配置文件。

1、properties 基本语法🍉

properties 是以键值对的形式配置的,key 和 value 之间是以“=”连接的,如

# 配置项⽬端⼝号(使用 # 号来进行注释说明)
server.port=8084
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/testdb?characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root

使用上篇文章的SpringBoot项目SpringBoot的创建和使用_冷兮雪的博客-CSDN博客

我去修改项目端口号,修改为8888 

#配置项目端口号
server.port=8888

启动项目:

可以看到控制台里显示端口号已被修改为:8888,我们浏览器打开:

 浏览器也可以正常打开项目,修改端口号成功。

2、读取配置文件🍉

Ⅰ、@Value 注解🍓

如果想要主动的读取项目中配置文件的内容,可以使用 @Value 注解来实现。

@Value 注解使用“${}”的格式读取,如下代码所示:

#配置项目端口号
server.port=8888
myName=孙悟空

修改了端口号 ,设置了myName属性,通过@Value 注解去读取,运行代码。

TestController

package com.example.springbootdemo;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
/*@RestController*/ //复合注解 = @Controller+@ResponseBody
public class TestController {
    //读取配置文件 myName=张三
    @Value("myName")
    private String myName;

    //请求映射 url 路由注册
    @RequestMapping("hi")
    public String sayHi(String s){
        //为空为null 默认值处理
        //if (s==null||s.equals("")){}   正常写法
        if(!StringUtils.hasLength(s)){  //Spring中更简单的写法 判断是否有长度
            s="张三";
        }

        return "你好"+myName;
    }
}

 ???难道读取错误了吗?我的myName不是设置的孙悟空吗?why?

上面我们说了:@Value 注解使用“${}”的格式读取

所以直接使用双引号去读取这是错误的,这是一个错误示范

正确写法:

继续运行代码:

 发现出现了乱码,这时可能有两种情况,1是读取的就是乱码,2是返回的乱码。我们可以去进行debug查看,找找原因。打好断点进行debug查看:

可以发现,原来我们读取的就是乱码,那么这个问题怎么去解决呢?

Ⅱ、解决读取乱码🍓

这在properties中也是一大痛点,因为在yml中就不会出现这类问题,我们需要额外在配置文件中去进行配置,这样才不会出现乱码问题。

添加下面配置,运行代码:

@PropertySource(value="classpath:/application.properties",encoding = "utf-8")

成功显示孙悟空。但是需要注意:

还不行看看这两篇文章:

Spring中使用@Value注解读取xxx.properties文件乱码问题_血莲丹的博客-CSDN博客

SpringBoot @Value中文乱码解决_51CTO博客_java中文乱码解决

Ⅲ、properties 缺点分析 🍓

 properties 配置是以 key-value 的形式配置的 ,但这样就无法避免配置文件中会有很多的冗余的信息。想要解决这个问题,可以使用 yml 配置文件的格式化。

四、yml 配置文件 🍭

yml 是 YAML 是缩写,它的全称 Yet Another Markup Language 翻译成中文就是“另一种标记⾔”。

 yml 优点分析 🍓

  • yml 是⼀个可读性高,写法简单、易于理解,它的语法和 JSON 语⾔类似。
  • yml 支持更多的数据类型,它可以简单表达清单(数组)、散列表,标量等数据形态。它使用空白符号缩进和大量依赖外观的特色,特别适合用来表达或编辑数据结构、各种配置文件等。
  • yml 支持更多的编程语言,它不止是 Java 中可以使⽤在 Golang、PHP、Python、Ruby、 JavaScript、Perl 中

1、yml 基本语法 🍉

yml 是树形结构的配置文件,它的基础语法是“key: value”,注意 key 和 value 之间使用英文冒汗加空格的方式组成的,其中的空格不可省略。

其中第一项的配置为正确的,key 也是高亮显示的,而第二项没有空格是错误的使用方式,第二项的 key 也没有高亮显示。

而在我的破解版上如果格式错误就会直接报错:

Ⅰ、yml与properties的格式对比🍓

properties:

 yml:

 肉眼可以看出yml树状结果在很大程度上减少了配置的冗余。

2、yml的使用🍉

yml的配置文件读取的和properties基本一样,都是使用@Value注解,格式都@Value("${}")。

现在来看看下面简单代码的运行

application.yml

#正确配置方式
myText: java

#错误配置方式
#myText:java

 TestController

package com.example.springbootdemo;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Controller;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
/*@RestController*/ //复合注解 = @Controller+@ResponseBody
//导入外部资源的注解上 加入encoding配置
@PropertySource(value="classpath:/application.properties",encoding = "utf-8")
public class TestController {
    //读取配置文件 myName=张三
//    @Value("myName")错误示范
    @Value("${myName}")
    private String myName;
    @Value("${myText}")
    private String myText;

    //请求映射 url 路由注册
    @RequestMapping("hi")
    public String sayHi(String s){
        //为空为null 默认值处理
        //if (s==null||s.equals("")){}   正常写法
        if(!StringUtils.hasLength(s)){  //Spring中更简单的写法 判断是否有长度
            s="张三";
        }

        return "你好"+myText+" + "+myName;
    }
}

运行显示 :

前面我们已经解决了properties配置文件读取中文乱码问题,如果我们未去解决,那myName将是乱码显示,而yml无需配置则可以显示中文。我们将myText改成猪八戒,运行代码试试:

可以看到yml可以正常读取中文。

3、yml 使用进阶🍉

Ⅰ、yml 配置不同数据类型及 null🍓

# 字符串
string.value: Hello
# 布尔值,true或false
boolean.value: true
boolean.value1: false
# 整数
int.value: 10
int.value1: 0b1010_0111_0100_1010_1110 # ⼆进制
# 浮点数
float.value: 3.14159
float.value1: 314159e-5 # 科学计数法
# Null,~代表null
null.value: ~

下面这样写不能出现关键字,不然会报空指针异常 

# 字符串
string:    #不能为关键字
  value: hello
#布尔类型
booLean:    #不能为关键字
  value1: true
  value2: false
# 整数
Int:    #不能为关键字
  value1: 10
  value2: 0b1010_0111_0100_1010_1110	# 二进制
# 浮点数
fLoat:    #不能为关键字
  value1: 3.1415926
  value2: 314159e-5	#科学计数法
# Null, ~ 表示 null
nUll:    #不能为关键字
  value: ~

 读取方式还是一样的:

读取值为null的配置,可以发现什么都没有,为空

Ⅱ、注意事项:value 值加单双引号——字符串🍓

字符串默认不用加上单引号或者双引号,如果加英文的单双引号可以表示特殊的含义

string:
  value: hello
  str1: Hello \n 你好.
  str2: 'Hello \n 你好.'
  str3: "Hello \n 你好."

运行下面代码: 

package com.example.springbootdemo;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Controller;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.annotation.PostConstruct;

@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
/*@RestController*/ //复合注解 = @Controller+@ResponseBody
//导入外部资源的注解上 加入encoding配置
@PropertySource(value="classpath:/application.properties",encoding = "utf-8")
public class TestController {
    //读取配置文件 myName=张三
//    @Value("myName")错误示范
    @Value("${string.str1}")
    private String str1;
    @Value("${string.str2}")
    private String str2;
    @Value("${string.str3}")
    private String str3;

    @PostConstruct//声明方法
    public void postConstruct(){
        System.out.println("string.str1:" + str1);
        System.out.println("string.str2:" + str2);
        System.out.println("string.str3:" + str3);
    }

}

 可以发现在双引号时str3 \n 进行了换行

由此可以得出结论:
  • 字符串默认不用加上单引号或者双引号。
  • 单引号会转义特殊字符,特殊字符最终只是⼀个普通的字符串数据。
  • 双引号不会转义字符串里面的特殊字符;特殊字符会作为本身想表示的意思

 Ⅲ、配置对象🍓

我们还可以在 yml 中配置对象,如下配置:

student:
 id: 1
 name: Java
 age: 18

或者是使用行内写法(与上面的写法作用一致):

student: {id: 1,name: Java,age: 18}

这个时候就不能用 @Value 来读取配置中的对象了(是一整个对象,而不是对象的属性),此时要使用另一个注解 @ConfigurationProperties 来读取,具体实现如下:

新建一个Student类

package com.example.springbootdemo;

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

@Component
@ConfigurationProperties(prefix = "student")
@Data //lombok中的注解,提供getter和setter方法还要toString方法
public class Student {
    private int id;
    private String name;
    private int age;
}

注意:以上代码中的 getter 和 setter 方法不能省略,要么使用@Data注解,要么生成getter 和 setter 方法。因为类中的值 赋值与取值 需要getter 和 setter 方法。

调用类TestController:

package com.example.springbootdemo;

import org.springframework.beans.factory.annotation.Autowired;


import javax.annotation.PostConstruct;

@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
/*@RestController*/ //复合注解 = @Controller+@ResponseBody
public class TestController {
    //读取配置文件 myName=张三
//    @Value("myName")错误示范

    @Autowired
    private Student student;

    @PostConstruct//声明方法
    public void postConstruct(){
        System.out.println(student);
    }
}

运行代码:

Ⅳ、配置集合🍓

配置文件也可以配置 list 集合:或者是使用行内写法(与上面的写法作用一致)

types:
  name:
    - mysql
    - sqlserver
    - db2

或者是使用行内写法(与上面的写法作用一致)

types: {name: [mysql,sqlserver,db2]}

集合的读取和对象一样,也是使用@ConfigurationProperties 来读取的,具体实现如下:

@Component
@ConfigurationProperties("dbtypes")
@Data
public class ListConfig {
 private List<String> name;
}

TestController 类

package com.example.springbootdemo;

import org.springframework.beans.factory.annotation.Autowired;


import javax.annotation.PostConstruct;

@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
/*@RestController*/ //复合注解 = @Controller+@ResponseBody
public class TestController {
    //读取配置文件 myName=张三
//    @Value("myName")错误示范

    @Autowired
    private  ListConfig listConfig;

    @PostConstruct//声明方法
    public void postConstruct(){
        System.out.println(listConfig.getName());
    }
}

查看更多系统配置项🍓

官方文档

面试突击75:SpringBoot 有几种读取配置文件的方法? - 掘金 (juejin.cn)

五、properties VS yml🍭

  • properties 是以 key=value 的形式配置的键值类型的配置文件,而 yml 使用的是类似 json 格式的树形配置方式进行配置的,yml 层级之间使用换行缩进的方式配置,key 和 value 之间使用“: ”英文冒号加空格的方式设置,并且空格不可省略。
  • properties 为早期并且默认的配置文件格式,但其配置存在一定的冗余数据,使用 yml 可以很好的解决数据冗余的问题。
  • yml 通用性更好,支持更多语⾔,如 Java、Go、Python 等,如果是云服务器开发,可以使用⼀份配置文件作为 Java 和 Go 的共同配置文件。
  • yml 支持更多的数据类型

六、设置不同环境的配置文件🍭

Ⅰ、创建不同环境的配置文件:🍓

  • application-dev.yml(开发环境)
  • application-prod.yml(生产环境)
  • 其他环境

一定是 application-开头。

在 application.yml 中设置运行环境🍓

现在设置配置环境可以使用下面很方便的方法,下面active的值为dev,即为开发环境,如果是prod则为生成环境

spring:
  profiles:
    active: dev

Ⅲ、代码演示🍓

application-dev.yml
server:
  port: 9999

 application-prod.yml

server:
  port: 7777

 设置不同的端口号,然后运行代码:

可以发现端口号变成了application-dev.yml中设置的端口号,

spring:
  profiles:
    active: prod

dev修改成prod,端口号就变成了 7777

这就很方便修改配置环境了

  • 145
    点赞
  • 143
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 182
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 182
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

热爱编程的林兮

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值