您的位置:首页技术文章
文章详情页

Spring @Value注解失效问题解决方案

【字号: 日期:2023-09-12 13:06:27浏览:6作者:猪猪

项目使用的是SSM体系,spring的配置如下,配置没问题,因为我发现其他文件中的@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自动注册Bean,Controllerller --> <context:component-scan base-package='com.magicmed.ecg' use-default-filters='false'> <!--base-package 如果多个,用“,”分隔--> <context:include-filter type='annotation' expression='org.springframework.stereotype.Controller' /> </context:component-scan> <!-- 自定义注解实现日志记录 --> <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 > <property name='locations' > <list> </list> </property> <property name='ignoreUnresolvablePlaceholders' value='true' /> </bean> <!-- 导入配置文件--> <import resource='classpath*:mybatis-spring.xml' /> <import resource='classpath*:mail-spring.xml' /> <import resource='classpath*:rabbitmq-spring.xml' /></beans>

失效的@Value是Parser这个父类的一个属性上的注解,而Parser的两个子类Parser1与Parser2继承这个属性;我的目的就是先用Parser执行一定得判断逻辑——判断版本号,如果是版本1就用Parser1读取文件,如果是版本2就用Parser2读取文件。经过我的测试,我发现Parser使用fileRoot属性是不为null,也就是注入成功了,而Parser怎么也注入不成功,fileRoot的值为null。 代码如下:

// parse@Componentpublic 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(); //获取根节点元素对象 } 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@Componentpublic 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@Componentpublic 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; }}

@Servicepublic 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; }}

刚开始我也怀疑配置文件,也怀疑缓存的问题。后来我在网上查阅资料,找到这样一段话,茅塞顿开:

原因是如果有注入bean的那个类,在被其他类作为对象引用的话(被调用)。这个被调用的类也必须选择注解的方式,注入到调用他的那个类中,不能用 new出来做对象,new出来的对象再注入其他bean就会 发生获取不到的现象。所以要被调用的javabean,都需要@service,交给Spring去管理才可以,这样他就默认注入了。

于是我把代码改成如下形式,注入成功了。

@Servicepublic 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; }}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持好吧啦网。

标签: Spring
相关文章: