溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Spring@Value屬性注入使用方法解析

發(fā)布時間:2020-09-27 02:24:32 來源:腳本之家 閱讀:238 作者:炫舞風(fēng)中 欄目:編程語言

這篇文章主要介紹了Spring@Value屬性注入使用方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

在使用Spring框架的項目中,@Value是使用比較頻繁的注解之一,它的作用是將配置文件中key對應(yīng)的值賦值給它標(biāo)注的屬性。在日常使用中我們常用的功能都比較簡單,本篇文章系統(tǒng)的帶大家來了解一下@Value的使用方法。

@Value注入支持形式

@Value屬性注入功能根據(jù)注入的內(nèi)容來源可分為兩類:通過配置文件的屬性注入和通過非配置文件的屬性注入。

通過配置文件的注入根據(jù)配置文件的來源又可分為兩類:一類為默認(rèn)的Spring Boot會自動加載的配置文件application.properties中的屬性;另一類為自定義配置文件中的屬性,需要先通過@PropertySource加載。

而非配置文件注入的類型又分為:

  • 注入普通字符串
  • 注入操作系統(tǒng)屬性
  • 注入表達式結(jié)果
  • 注入其他Bean屬性
  • 注入文件資源
  • 注入URL資源

基于配置文件注入
首先來看數(shù)據(jù)來源自配置文件的注入,無論是會被默認(rèn)加載的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注入單個屬性,還可以注入數(shù)組和列表形式。比如如下配置:

tools=car,train,airplane

可以通過以下方式注入:

/**
 * 注入數(shù)組(自動根據(jù)","分割)
 */
@Value("${tools}")
private String[] toolArray;

/**
 * 注入列表形式(自動根據(jù)","分割)
 */
@Value("${tools}")
private List<String> toolList;

Spring默認(rèn)情況下會以“,”進行分割,轉(zhuǎn)換成對應(yīng)的數(shù)組或列表。

基于非配置文件注入

在使用實例說明基于非配置文件注入屬性的實例之前,我們先了解一下SpEL。

SpEL(Spring Expression Language)即Spring表達式語言,可以在運行時查詢和操作數(shù)據(jù)。使用#{...}作為定界符, 所有在大括號中的字符都將被認(rèn)為是 SpEL。

下面看具體實例場景的應(yīng)用:

/**
 * 注入普通字符串,相當(dāng)于直接給屬性默認(rèn)值
 */
@Value("程序新視界")
private String wechatSubscription;

/**
 * 注入操作系統(tǒng)屬性
 */
@Value("#{systemProperties['os.name']}")
private String systemPropertiesName;

/**
 * 注入表達式結(jié)果
 */
@Value("#{ T(java.lang.Math).random() * 100.0 }")
private double randomNumber;

/**
 * 注入其他Bean屬性:注入config對象的屬性tool
 */
@Value("#{config.tool}")
private String tool;

/**
 * 注入列表形式(自動根據(jù)"|"分割)
 */
@Value("#{'${words}'.split('\\|')}")
private List<String> numList;

/**
 * 注入文件資源
 */
@Value("classpath:config.xml")
private Resource resourceFile;

/**
 * 注入URL資源
 */
@Value("http://www.choupangxia.com")
private URL homePage;

在上述示例分別展示了以下場景的使用:

  • 直接注入字符串,相當(dāng)于實例化時直接初始化字符串。
  • 通過#{}注入系統(tǒng)屬性。
  • 通過#{}注入表達式結(jié)果。
  • 通過#{}注入其他Bean的屬性。
  • 通過#{}和${}的組合注入屬性并進行分割處理。
  • 注入文件資源,將對應(yīng)的字符串值轉(zhuǎn)換成對應(yīng)的資源文件。
  • 注入URL資源,將對應(yīng)的URL字符串轉(zhuǎn)換成URL。

其中需要注意的是:

  • Resource的全限定名為org.springframework.core.io.Resource。
  • 二者結(jié)合使用時(#{'${}'}),注意單引號,注意不能反過來。

默認(rèn)值注入

無論使用#{}或${}進行屬性的注入,當(dāng)無法獲取對應(yīng)值時需要設(shè)置默認(rèn)值,可以采用如下方式來進行設(shè)置。

/**
 * 如果屬性中未配置ip,則使用默認(rèn)值
 */
@Value("${ip:127.0.0.1}")
private String ip;

/**
 * 如果系統(tǒng)屬性中未獲取到port的值,則使用8888。
 */
@Value("#{systemProperties['port']?:'8888'}")
private String port;

其中${}中直接使用“:”對未定義或為空的值進行默認(rèn)值設(shè)置,而#{}則需要使用“?:”對未設(shè)置的屬性進行默認(rèn)值設(shè)置。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI