这篇文章主要介绍了spring@value属性注入使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
在使用spring框架的项目中,@value是使用比较频繁的注解之一,它的作用是将配置文件中key对应的值赋值给它标注的属性。在日常使用中我们常用的功能都比较简单,本篇文章系统的带大家来了解一下@value的使用方法。
@value注入支持形式
@value属性注入功能根据注入的内容来源可分为两类:通过配置文件的属性注入和通过非配置文件的属性注入。
通过配置文件的注入根据配置文件的来源又可分为两类:一类为默认的spring boot会自动加载的配置文件application.properties中的属性;另一类为自定义配置文件中的属性,需要先通过@propertysource加载。
而非配置文件注入的类型又分为:
基于配置文件注入
首先来看数据来源自配置文件的注入,无论是会被默认加载的application.properties或自定义的my.properties文件。比如,application.properties中定义属性值的形式如下:
user.name=admin
在my.properties配置文件中定义的属性如下:
user.password=pwd123
那么,@value在bean中的使用形式为:
@propertysource("classpath:my.properties") @restcontroller public class valuecontroller { /** * 获取位于application.properties中配置的属性 */ @value("${user.name}") private string name; /** * 获取位于my.properties中的配置属性 */ @value("${user.password}") private string password; }
不同的是,在spring boot项目中,如果是自定义的my.properties文件,需要在某个类中通过@propertysource引入该配置文件,而application.properties中的属性会自动被加载。
同时,不仅仅可以通过@value注入单个属性,还可以注入数组和列表形式。比如如下配置:
tools=car,train,airplane
可以通过以下方式注入:
/** * 注入数组(自动根据","分割) */ @value("${tools}") private string[] toolarray; /** * 注入列表形式(自动根据","分割) */ @value("${tools}") private list<string> toollist;
spring默认情况下会以“,”进行分割,转换成对应的数组或列表。
基于非配置文件注入
在使用实例说明基于非配置文件注入属性的实例之前,我们先了解一下spel。
spel(spring expression language)即spring表达式语言,可以在运行时查询和操作数据。使用#{...}作为定界符, 所有在大括号中的字符都将被认为是 spel。
下面看具体实例场景的应用:
/** * 注入普通字符串,相当于直接给属性默认值 */ @value("程序新视界") private string wechatsubscription; /** * 注入操作系统属性 */ @value("#{systemproperties['os.name']}") private string systempropertiesname; /** * 注入表达式结果 */ @value("#{ t(java.lang.math).random() * 100.0 }") private double randomnumber; /** * 注入其他bean属性:注入config对象的属性tool */ @value("#{config.tool}") private string tool; /** * 注入列表形式(自动根据"|"分割) */ @value("#{'${words}'.split('\\|')}") private list<string> numlist; /** * 注入文件资源 */ @value("classpath:config.xml") private resource resourcefile; /** * 注入url资源 */ @value("http://www.choupangxia.com") private url homepage;
在上述示例分别展示了以下场景的使用:
其中需要注意的是:
默认值注入
无论使用#{}或${}进行属性的注入,当无法获取对应值时需要设置默认值,可以采用如下方式来进行设置。
/** * 如果属性中未配置ip,则使用默认值 */ @value("${ip:127.0.0.1}") private string ip; /** * 如果系统属性中未获取到port的值,则使用8888。 */ @value("#{systemproperties['port']?:'8888'}") private string port;
其中${}中直接使用“:”对未定义或为空的值进行默认值设置,而#{}则需要使用“?:”对未设置的属性进行默认值设置。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。
如对本文有疑问, 点击进行留言回复!!
springmvc之ResponseBody响应json数据遇到的错误及解决
uni-app 后台升级 静默升级 uniapp 后台更新 静默更新 在线升级
SpringBoot多Module启动报错Could not transfer metadata
Hibernate项目报错:Cannot call sendError() after the response has been committed
网友评论