1. @Value("${变量名称}")
使用@Value("${变量名称}")是最简单的一种形式
代码中直接通过该方式引用即可
public class MicroGatewayConfig {
@Value("${config}")
private String config;
}
这种方式简单粗暴,但是不推荐使用,
缺点很多
- idea也给我们报黄色的警告。而且我们不能再配置文件中按住“ctrl”鼠标点击配置变量直接跳到程序中。如果我们的项目中使用大量这样的变量,将会是灾难。
- 最致命的问题是程序中变量获取到的值只能是字符串,不能支持数字,布尔类型。
-
使用这种形式,变量的值只会在SpringBoot启动的时候赋值一次,以后不会改变,如果我们使用了配置中心,随后,我们即使更新了配置中心中配置信息的值,程序也不会同步,除非我们重启项目,配置中心就显得比较尴尬。
2.1 配置类
@Setter
@Getter
@Component
@ConfigurationProperties("spring.cloud.gateway.custom")
public class MicroGatewayConfig {
/**
* config demo
*/
private String config;
}
@ConfigurationProperties
注解内容填写的是这个配置变量的前缀
这样配置信息就以类的形成呈现出来,如果我们需要使用配置信息,直接通过@Resource
注入即可。在配置文件中,也不会报警告,在编写配置信息的时候,强大的idea也会帮我们联想。
2.2 配置类嵌套
当我们的配置信息越来越多时,需要针对不同的配置进行分类,如果全部编写在同一个配置类中,那么这个配置类会显得十分臃肿。
springBoot支持配置类嵌套的形式。
举个例子
我现在网关通过配置文件中的“开关”决定是否对请求信息进行缓存。
这样,我们可以将关于请求缓存相关的配置信息单独一个类进行保存。
- 缓存配置类
@Data
@Component
@ConfigurationProperties("spring.cloud.gateway.custom.cache-request")
public class CacheRequestConfig {
/**
* 是否缓存body信息
*/
private Boolean body = false;
/**
* 是否缓存表单信息
*/
private Boolean formData = false;
/**
* 是否缓存encodeBody信息
*/
private Boolean encodeFormData = false;
}
- 主配置类
@Setter
@Getter
@Component
@ConfigurationProperties("spring.cloud.gateway.custom")
public class MicroGatewayConfig {
private CacheRequestConfig cacheRequest;
}
-
配置文件
image.png
我们在编写配置类的时候,可以发现一个有趣的事情,就是针对于布尔类型,我们除了使用true/false外,还可以使用on/off进行代替,在程序中springBoot会自动替我们转换成true/false。这样增强了配置的可读性。
2.3 List配置信息
我们在配置信息中有时候可能需要配置一个list,比如配置redis的集群ip信息。之前我们可以使用一个字符串代替,每个ip中间使用特定的符号隔开,然后在程序中自己手动的去分隔。
强大的yml支持List,表达形式是每个元素前面使用“-”+空格
eg:
配置一个redis集群列表
- 配置类
@Data
@Component
@ConfigurationProperties("spring.cloud.gateway.custom")
public class MicroGatewayConfig {
private CacheRequestConfig cacheRequest;
private List<String> redisClusterPortList;
}
- 配置信息
spring:
cloud:
gateway:
custom:
cache-request:
body: true
form-data: true
encode-form-data: on
redisClusterPortList:
- 192.168.1.1
- 196.168.1.0
2.3 Map配置信息
yml使用map的格式为:
map变量名
key: value
key: value
这里举例配置一个日志打印相关的
- 配置类
@Data
@Component
@ConfigurationProperties("spring.cloud.gateway.custom")
public class MicroGatewayConfig {
private CacheRequestConfig cacheRequest;
private List<String> redisClusterPortList;
private Map<String,Boolean> logPrint;
}
- 配置信息
spring:
cloud:
gateway:
custom:
cache-request:
body: true
form-data: true
encode-form-data: on
redisClusterPortList:
- 192.168.1.1
- 196.168.1.0
logPrint:
printRequestHeader: false
printResponseHeader: false
printRequestBody: false
printResponseBody: false
map的形式个人不推荐使用,因为我们编写的key-value没有在配置文件中体现出来,可读性可能会差一点,如果我们使用map中的key,还需要使用一个常量类去记录map中存了啥,感觉实在是多此一举,map也完全可以通过自己编写配置类实现。
网友评论