ref:https://blog.csdn.net/zhangzehai2234/article/details/88564759


@Value注解的使用:

  • 没有默认值的用法:
@Value("${spring.port}")
private String port;

配置文件:

spring:
  port: 8080

则:上面这样 就会自动的将配置文件中的值 注入到属性中去。


使用@Value注解将配置文件中配置的值 进行自动注入的时候,经常会出现的一个问题就是:若我们忘记在配置文件中配置该参数 则会造成项目启动报错。

我们可以通过给被@Value注解作用的变量进行注入的时候,如果没有找到该配置参数时 设置一个默认值,相当于是一个兜底的方案。

  • 增加默认值的用法:
@Value("${spring.port:8080}")
private String port;

这样即使忘记 在配置文件中配置参数,项目启动也不会报错。

这里需要注意的是:

  • 即使你的配置参数的值是String类型的话也不需要加双引号
  • 被static修饰的变量通过@Value会注入失败

如果是因为特定需求必须要给static变量进行@Value设值的话,可以采用下面这种方式

给static变量采用@Value设值

Test.java

public static String port;

@Value("${spring.port:8080}")
public void setPort(String port){
	Test.port = port;
}


考虑几种情况:
1、配置文件中没有配置项:可以使用@Value注解 设置默认值。

@Value("${spring.port:8080}")
private String port;

2、若配置文件中有配置项,但是没有配置value。
这时,就需要 给变量赋初值,否则 拿到的就是默认值,Int类型0,String类型 “”。

@Value("${spring.port:8080}")
private String port = 8090;

@Value("${schedule.overview.dashboard_time:180}")
private Integer dashboard = 280;
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐