在使用Spring框架的项目中,@Value是使用比较频繁的注解之一,它的作用是将配置文件中key对应的值赋值给它标注的属性。在日常使用中我们常用的功能都比较简单,本篇文章系统的带大家来了解一下@Value的使用方法。

@Value属性注入功能根据注入的内容来源可分为两类:通过配置文件的属性注入和通过非配置文件的属性注入。

通过配置文件的注入根据配置文件的来源又可分为两类:一类为默认的Spring Boot会自动加载的配置文件application.properties中的属性;另一类为自定义配置文件中的属性,需要先通过@PropertySource加载。

而非配置文件注入的类型又分为:

  • 注入普通字符串
  • 注入操作系统属性
  • 注入表达式结果
  • 注入其他Bean属性
  • 注入文件资源
  • 注入URL资源

首先来看数据来源自配置文件的注入,无论是会被默认加载的application.properties或自定义的my.properties文件。比如,application.properties中定义属性值的形式如下:

  1. user.name=admin

在my.properties配置文件中定义的属性如下:

  1. user.password=pwd123

那么,@Value在Bean中的使用形式为:

  1. @PropertySource("classpath:my.properties")
  2. @RestController
  3. public class ValueController {
  4. /**
  5. * 获取位于application.properties中配置的属性
  6. */
  7. @Value("${user.name}")
  8. private String name;
  9. /**
  10. * 获取位于my.properties中的配置属性
  11. */
  12. @Value("${user.password}")
  13. private String password;
  14. }

不同的是,在Spring Boot项目中,如果是自定义的my.properties文件,需要在某个类中通过@PropertySource引入该配置文件,而application.properties中的属性会自动被加载。

同时,不仅仅可以通过@Value注入单个属性,还可以注入数组和列表形式。比如如下配置:

  1. tools=car,train,airplane

可以通过以下方式注入:

  1. /**
  2. * 注入数组(自动根据","分割)
  3. */
  4. @Value("${tools}")
  5. private String[] toolArray;
  6. /**
  7. * 注入列表形式(自动根据","分割)
  8. */
  9. @Value("${tools}")
  10. private List<String> toolList;

Spring默认情况下会以“,”进行分割,转换成对应的数组或列表。

在使用实例说明基于非配置文件注入属性的实例之前,我们先了解一下SpEL。

SpEL(Spring Expression Language)即Spring表达式语言,可以在运行时查询和操作数据。使用#{…}作为定界符, 所有在大括号中的字符都将被认为是 SpEL。

下面看具体实例场景的应用:

  1. /**
  2. * 注入普通字符串,相当于直接给属性默认值
  3. */
  4. @Value("程序新视界")
  5. private String wechatSubscription;
  6. /**
  7. * 注入操作系统属性
  8. */
  9. @Value("#{systemProperties['os.name']}")
  10. private String systemPropertiesName;
  11. /**
  12. * 注入表达式结果
  13. */
  14. @Value("#{ T(java.lang.Math).random() * 100.0 }")
  15. private double randomNumber;
  16. /**
  17. * 注入其他Bean属性:注入config对象的属性tool
  18. */
  19. @Value("#{config.tool}")
  20. private String tool;
  21. /**
  22. * 注入列表形式(自动根据"|"分割)
  23. */
  24. @Value("#{'${words}'.split('\\|')}")
  25. private List<String> numList;
  26. /**
  27. * 注入文件资源
  28. */
  29. @Value("classpath:config.xml")
  30. private Resource resourceFile;
  31. /**
  32. * 注入URL资源
  33. */
  34. @Value("http://www.choupangxia.com")
  35. private URL homePage;

在上述示例分别展示了以下场景的使用:

  • 直接注入字符串,相当于实例化时直接初始化字符串。
  • 通过#{}注入系统属性。
  • 通过#{}注入表达式结果。
  • 通过#{}注入其他Bean的属性。
  • 通过#{}和${}的组合注入属性并进行分割处理。
  • 注入文件资源,将对应的字符串值转换成对应的资源文件。
  • 注入URL资源,将对应的URL字符串转换成URL。

其中需要注意的是:

  • Resource的全限定名为org.springframework.core.io.Resource。
  • 二者结合使用时(#{‘${}’}),注意单引号,注意不能反过来。

无论使用#{}或${}进行属性的注入,当无法获取对应值时需要设置默认值,可以采用如下方式来进行设置。

  1. /**
  2. * 如果属性中未配置ip,则使用默认值
  3. */
  4. @Value("${ip:127.0.0.1}")
  5. private String ip;
  6. /**
  7. * 如果系统属性中未获取到port的值,则使用8888。
  8. */
  9. @Value("#{systemProperties['port']?:'8888'}")
  10. private String port;

其中${}中直接使用“:”对未定义或为空的值进行默认值设置,而#{}则需要使用“?:”对未设置的属性进行默认值设置。

原文链接:《SpringBoot之Spring@Value属性注入使用详解

CSDN学院:《Spring Boot 视频教程全家桶》

程序新视界:精彩和成长都不容错过

程序新视界-微信公众号

版权声明:本文为secbro原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/secbro/p/12095837.html