Spring 開發過程中Value 注解的使用場景
Spring 開發過程中使用 Value 注解對屬性進行賦值;常見的場景有三種。
直接對屬性進行賦值;包括普通字符串、操作系統屬性、文件內容等。 從配置文件中讀取簡單類型進行賦值;配置文件需要生效才可。 從配置文件中讀取復雜類型進行賦值;如數組、Map、對象列表等。一、直接對屬性進行賦值
通過 @Value 將外部的值動態注入到Bean中,使用的情況有:
注入普通字符串 注入操作系統屬性 注入表達式結果 注入其他Bean屬性:注入beanInject對象的屬性another 注入文件資源 注入URL資源@Value('normal')private String normal; // 注入普通字符串@Value('#{systemProperties[’os.name’]}')private String systemPropertiesName; // 注入操作系統屬性@Value('#{ T(java.lang.Math).random() * 100.0 }')private double randomNumber; //注入表達式結果@Value('#{beanInject.another}')private String fromAnotherBean; // 注入其他Bean屬性:注入beanInject對象的屬性another,類具體定義見下面@Value('classpath:com/hry/spring/configinject/config.txt')private Resource resourceFile; // 注入文件資源@Value('http://www.baidu.com')private Resource testUrl; // 注入URL資源
二、從配置文件中讀取簡單類型進行賦值
通過 @Value 將外部配置文件的值動態注入到Bean中。
2.1、默認自動加載配置
Spring boot 啟動過程中會自動默認加載配置文件 application.propreties(application.yml);這樣的話,配置文件中的配置項,可以直接被 Value 注解使用。如果放置在其他配置文件中的話,只要保證啟動時會被加載即可;配置方式有好幾種,這里就不贅述了。
2.2、使用注解指定加載的配置文件
自定義配置文件通過 @PropertySource 注解加載。@PropertySource可以同時加載多個文件,也可以加載單個文件。如果相同第一個屬性文件和第二屬性文件存在相同key,則最后一個屬性文件里的key啟作用。加載文件的路徑也可以使用變量定義。
2.3、配置文件加載示例
1、config.properties 配置文件
book.name=bookNameanotherfile.configinject=placeholder //作為第二個配置文件加載路徑的變量值
2、config_placeholder.properties 配置文件
book.name.placeholder=bookNamePlaceholder
3、下面通過@Value(“${app.name}”)語法將屬性文件的值注入bean屬性值
@Component// 引入外部配置文件組:${app.configinject}的值來自config.properties。// 如果相同@PropertySource({'classpath:com/hry/spring/configinject/config.properties', 'classpath:com/hry/spring/configinject/config_${anotherfile.configinject}.properties'})public class ConfigurationFileInject{ @Value('${app.name}') private String appName; // 這里的值來自application.properties,spring boot啟動時默認加載此文件 @Value('${book.name}') private String bookName; // 注入第一個配置外部文件屬性 @Value('${book.name.placeholder}') private String bookNamePlaceholder; // 注入第二個配置外部文件屬性 @Autowired private Environment env; // 注入環境變量對象,存儲注入的屬性值 public String toString(){ StringBuilder sb = new StringBuilder(); sb.append('bookName=').append(bookName).append('rn') .append('bookNamePlaceholder=').append(bookNamePlaceholder).append('rn') .append('appName=').append(appName).append('rn') .append('env=').append(env).append('rn') // 從eniroment中獲取屬性值 .append('env=').append(env.getProperty('book.name.placeholder')).append('rn'); return sb.toString(); }}
三、從配置文件中讀取復雜類型進行賦值
Spring Boot 通過 Value 注解從配置文件中獲取Map、List或者對象列表類型的配置信息時,應該創建一個接受這些配置信息的對象。配置文件中的配置項,設置為此對象的屬性。
3.1、添加依賴包
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional></dependency>
3.2、創建接受配置信息的對象
@Configuration@Component@ConfigurationProperties(prefix = 'dingtalk')@EnableConfigurationProperties(MapConfig.class)public class MapConfig { /** * 從配置文件中讀取的dingtalk.urls開頭的數據 * 注意:名稱必須與配置文件中保持一致 */ private Map<String, String> urls; public Map<String, String> getUrls() { return urls; } public void setUrls(Map<String, String> urls) { this.urls = urls; }}
3.3、配置文件示例
dingtalk: urls: default: https://oapi.dingtalk.com/default test: https://oapi.dingtalk.com/test center: https://oapi.dingtalk.com/center
3.4、調用實例
@Componentpublic class test { @Autowired private MapConfig mapConfig;private Map<String,String> urlsMap; public void test { urlsMap = mapConfig.getUrls();System.out.println(urlsMap.toString());}}
以上就是Spring 開發過程中Value 注解的使用場景的詳細內容,更多關于spring value注解的資料請關注好吧啦網其它相關文章!
相關文章: