Spring @Value注解失效問題解決方案
項(xiàng)目使用的是SSM體系,spring的配置如下,配置沒問題,因?yàn)槲野l(fā)現(xiàn)其他文件中的@Value可以使用,只有一處@Value失效了。
spring-servlet.xml
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:websocket="http://www.springframework.org/schema/websocket" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd http://www.springframework.org/schema/websocket http://www.springframework.org/schema/websocket/spring-websocket.xsd"> <context:property-placeholder ignore-unresolvable="true" location="classpath*:config.properties" /> <!-- 使用Annotation自動(dòng)注冊(cè)Bean,Controllerller --> <context:component-scan base-package="com.magicmed.ecg" use-default-filters="false"> <!--base-package 如果多個(gè),用“,”分隔--> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" /> </context:component-scan> <!-- 自定義注解實(shí)現(xiàn)日志記錄 --> <aop:aspectj-autoproxy /> <mvc:annotation-driven /> <import resource="classpath:mybatis-spring.xml" /> <import resource="classpath:mail-spring.xml" /> <import resource="classpath:rabbitmq-spring.xml" /> </beans>
spring.xml
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/context http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer" > <property name="locations" > <list> </list> </property> <property name="ignoreUnresolvablePlaceholders" value="true" /> </bean> <!-- 導(dǎo)入配置文件--> <import resource="classpath*:mybatis-spring.xml" /> <import resource="classpath*:mail-spring.xml" /> <import resource="classpath*:rabbitmq-spring.xml" /> </beans>
失效的@Value是Parser這個(gè)父類的一個(gè)屬性上的注解,而Parser的兩個(gè)子類Parser1與Parser2繼承這個(gè)屬性;我的目的就是先用Parser執(zhí)行一定得判斷邏輯——判斷版本號(hào),如果是版本1就用Parser1讀取文件,如果是版本2就用Parser2讀取文件。經(jīng)過我的測(cè)試,我發(fā)現(xiàn)Parser使用fileRoot屬性是不為null,也就是注入成功了,而Parser怎么也注入不成功,fileRoot的值為null。 代碼如下:
// parse @Component public class Parser { @Value("${fileRoot}") protected String fileRoot; //文件根路徑 protected String getFilePath(String appuserId, String uri) { return fileRoot + appuserId + System.getProperty("file.separator")+ uri; } public Map<String, String> getXML_version(String appuserId, String uri) { Element root = null; try { Document document = new SAXReader().read(new File(getFilePath(appuserId, uri) + ".xml")); root = document.getRootElement(); //獲取根節(jié)點(diǎn)元素對(duì)象 } catch (DocumentException e) { e.printStackTrace(); } return root.element("XMLInfo").element("Version").getTextTrim(); } public Map<String, Object> read_xml(String appuserId, String uri) { return null; } } // parser1 @Component public class Parser1 extends Parser { @Override public Map<String, Object> read_xml(String appuserId, String uri) { try { InputStream in = new FileInputStream(new File(getFilePath(appuserId, uri) + ".xml")); } catch (IOException e) { e.printStackTrace(); } /** * 待處理的邏輯 */ return null; } } // parser2 @Component public class Parser2 extends Parser { @Override public Map<String, Object> read_xml(String appuserId, String uri) { try { InputStream in = new FileInputStream(new File(getFilePath(appuserId, uri) + ".xml")); } catch (IOException e) { e.printStackTrace(); } /** * 待處理的邏輯 */ return null; } }
@Service public class testServiceImpl implements testService { @Autowired private Parser parser; public Integer test(String id, String uri) { Map<String,String> versionMap = parser.getXML_version(id,uri); if(versionMap.get("mv").equals("1")){ parser = new Parser1(); }else if(versionMap.get("mv").equals("2")){ parser = new Pparser2(); } parser.read_xml(id,uri); return null; } }
剛開始我也懷疑配置文件,也懷疑緩存的問題。后來我在網(wǎng)上查閱資料,找到這樣一段話,茅塞頓開:
原因是如果有注入bean的那個(gè)類,在被其他類作為對(duì)象引用的話(被調(diào)用)。這個(gè)被調(diào)用的類也必須選擇注解的方式,注入到調(diào)用他的那個(gè)類中,不能用 new出來做對(duì)象,new出來的對(duì)象再注入其他bean就會(huì) 發(fā)生獲取不到的現(xiàn)象。所以要被調(diào)用的javabean,都需要@service,交給Spring去管理才可以,這樣他就默認(rèn)注入了。
于是我把代碼改成如下形式,注入成功了。
@Service public class testServiceImpl implements testService { @Autowired private Parser parser; @Autowired private Parser1 parser1; @Autowired private Parser2 parser2; public Integer test(String id, String uri) { Map<String,String> versionMap = parser.getXML_version(id,uri); if(versionMap.get("mv").equals("1")){ parser = parser1; }else if(versionMap.get("mv").equals("2")){ parser = parser2; } parser.read_xml(id,uri); return null; } }
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java?數(shù)據(jù)結(jié)構(gòu)與算法系列精講之貪心算法
我們可能在好多地方都會(huì)聽到貪心算法這一概念,并且它的算法思想也比較簡(jiǎn)單就是說算法只保證局部最優(yōu),進(jìn)而達(dá)到全局最優(yōu)。但我們實(shí)際編程的過程中用的并不是很多,究其原因可能是貪心算法使用的條件比較苛刻,所要解決的問題必須滿足貪心選擇性質(zhì)2022-02-02超簡(jiǎn)單的java獲取鼠標(biāo)點(diǎn)擊位置坐標(biāo)的實(shí)例(鼠標(biāo)在Jframe上的坐標(biāo))
在Java窗體Jframe上獲取鼠標(biāo)點(diǎn)擊的坐標(biāo),其中使用了匿名內(nèi)部類,實(shí)例代碼非常簡(jiǎn)單易懂,大家可以學(xué)習(xí)一下2018-03-03JSON 與對(duì)象、集合之間的轉(zhuǎn)換的示例
在開發(fā)過程中,經(jīng)常需要和別的系統(tǒng)交換數(shù)據(jù),數(shù)據(jù)交換的格式有XML、JSON等,JSON作為一個(gè)輕量級(jí)的數(shù)據(jù)格式比xml效率要高,本篇文章主要介紹了JSON 與 對(duì)象 、集合 之間的轉(zhuǎn)換,有興趣的可以了解一下。2017-01-01Struts2實(shí)現(xiàn)自定義攔截器的三種方式詳解
這篇文章主要介紹了Struts2實(shí)現(xiàn)自定義攔截器的三種方式詳解,一些與系統(tǒng)邏輯相關(guān)的通用功能如權(quán)限的控制和用戶登錄控制等,需要通過自定義攔截器實(shí)現(xiàn),本節(jié)將詳細(xì)講解如何自定義攔截器,需要的朋友可以參考下2023-07-07