結合SpEL使用@Value-基於配置文件或非配置的文件的值注入-Spring Boot
- 2020 年 7 月 9 日
- 筆記
本文主要介紹Spring @Value 註解注入屬性值的使用方法的分析,文章通過示例代碼非常詳細地介紹,對於每個人的學習或工作都有一定的參考學習價值
在使用spring框架的項目中,@Value是經常使用的註解之一。其功能是將與配置文件中的鍵對應的值分配給其帶註解的屬性。在日常使用中,我們常用的功能相對簡單。本文使您系統地了解@Value的用法。
@Value注入形式
根據注入的內容來源,@ Value屬性注入功能可以分為兩種:通過配置文件進行屬性注入和通過非配置文件進行屬性注入。
非配置文件注入的類型如下:
- 注入普通字符串
- 注入操作系統屬性
- 注射表達結果
- 注入其他bean屬性
- 注入文件資源
- 注入URL資源
基於配置文件的注入
首先,讓我們看一下配置文件中的數據注入,無論它是默認加載的application.properties還是自定義my.properties文檔(需要@PropertySource額外加載)。例如:application.properties屬性值以以下形式定義:
user.name=admin
my.properties配置文件中定義的屬性如下:
user.password=pwd123
然後,在bean中使用@Value,如下所示:
@PropertySource("classpath:my.properties")
@RestController
public class ValueController {
/**
*Get in application.properties Properties configured in
*/
@Value("${user.name}")
private String name;
/**
*Get in my.properties Configuration properties in
*/
@Value("${user.password}")
private String password;
}
區別在於,在spring boot項目中,如果使用my.properties文件,則需要通過類中的@ PropertySource導入配置文件,而application.properties中的屬性將自動加載。
同時,您不僅可以通過@Value注入單個屬性,還可以採用數組和列表的形式。例如,配置如下:
tools=car,train,airplane
可以通過以下方式注入它:
/**
*Injection array (automatically split according to ",")
*/
@Value("${tools}")
private String[] toolArray;
/**
*Injection list form (automatic segmentation based on "," and)
*/
@Value("${tools}")
private List<String> toolList;
默認情況下,spring將以「,」分割,並將其轉換為相應的數組或列表。
基於非配置文件的注入
在使用示例說明基於非配置文件注入屬性的實例之前,讓我們看一下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;
/**
*將words用「|」分隔為字符串數組
*/
@Value("#{'${words}'.split('\|')}")
private List<String> numList;
/**
*注入一個文件資源
*/
@Value("classpath:config.xml")
private Resource resourceFile;
/**
*注入 URL 資源
*/
@Value("//www.choupangxia.com")
private URL homePage;
上面的示例顯示了以下方案的使用:
- 直接注入字符串等效於實例化時直接初始化字符串。初始化空串
- 通過#{}注入系統變量。
- 表達式計算結果通過#{}注入。
- 通過#{}注入其他bean的屬性。
- 通過{}和$ {}的組合注入屬性,然後拆分。
- 注入文件資源,並將相應的字符串值轉換為相應的資源文件。
- 注入URL資源並將相應的URL字符串轉換為URL。
默認值注入
無論使用#{}(SpEL)還是$ {}進行屬性注入,當無法獲得相應的值時,都需要設置默認值,可以通過以下方式進行設置。
/**
*If IP is not configured in the property, the default value is used
*/
@Value("${ip:127.0.0.1}")
private String ip;
/**
*If the value of port is not obtained in the system properties, 8888 is used.
*/
@Value("#{systemProperties['port']?:'8888'}")
private String port;
$ {}中直接使用「:」來設置未定義或空值的默認值,而#{}則需要使用「?:」來設置未設置屬性的默認值。
歡迎關注我的博客,裏面有很多精品合集
- 本文轉載註明出處(必須帶連接,不能只轉文字):字母哥博客。
覺得對您有幫助的話,幫我點贊、分享!您的支持是我不竭的創作動力! 。另外,筆者最近一段時間輸出了如下的精品內容,期待您的關注。
- 《手摸手教你學Spring Boot2.0》
- 《Spring Security-JWT-OAuth2一本通》
- 《實戰前後端分離RBAC權限管理系統》
- 《實戰SpringCloud微服務從青銅到王者》
- 《VUE深入淺出系列》