1. 第一步檢測語法是否正確
@Value("${test}") private String test;
2.第二步檢測配置文件中是否有進行配置
url=test
username=username
password=password
3.第三步檢測是否增加了@Component注解
在spring中,使用了spring的注解,那么就需要使用spring來進行管理對象,而不能自己進行new,否則就會導致失敗。
@Component //將類交給spring進行對象管理 public class DBUtils { @Value("${url}") private String url; @Value("${username}") private String username; @Value("${password}") private String password; }
4.第四步檢測代碼中的書寫方式
不要再無參構造器中,進行new對象的操作。否則就會造成@Value注解失敗。(本人就是踩到這步坑)。
初始化上下文可以使用@PostConstruct注解來進行初始化,他會在spring加載完信息后,進行調用並且只調用一次。
5.@Value無法注入static屬性
使用@Value直接放在static的屬性上是無法注入內容的!!!此方式會一直是null.
原因
發現@value不能直接注入值給靜態屬性,spring 不允許/不支持把值注入到靜態變量中;spring支持set方法注入,我們可以利用非靜態setter 方法注入靜態變量,並且使用@Value的類必須交個spring進行管理.就如同@Autowired有時無法注入一樣.
詳細說明:https://blog.csdn.net/sqlgao22/article/details/100100314
改進
使用setter方法進行屬性的賦值,並且setter方法不能有static
idea自動生成的方法會有static,需要手動刪除.
@Component //將類交給spring進行對象管理 public class DBUtils { private static String url; private static String username; private static String password; @Value("${url}") //刪除掉static public void setUrl(String url) { DBUtils.url = url; } @Value("${username}") public void setUsername(String username) { DBUtils.username = username; } @Value("${password}") public void setPassword(String password) { DBUtils.password = password; } //查看是否注入 public static void get() { System.out.println("=====url====="+url); System.out.println("=====username====="+username); System.out.println("=====password====="+password); } }
測試
@RequestMapping("/get") @ResponseBody public String get() { DBUtils.get(); return "get"; }
測試后輸出:
成功注入屬性.
文章轉載至:https://blog.csdn.net/sqlgao22/article/details/100096348