项目使用的是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 id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer" >
<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
@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(); //获取根节点元素对象
} 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;
}
}
刚开始我也怀疑配置文件,也怀疑缓存的问题。后来我在网上查阅资料,找到这样一段话,茅塞顿开:
原因是如果有注入bean的那个类,在被其他类作为对象引用的话(被调用)。这个被调用的类也必须选择注解的方式,注入到调用他的那个类中,不能用 new出来做对象,new出来的对象再注入其他bean就会 发生获取不到的现象。所以要被调用的javabean,都需要@service,交给Spring去管理才可以,这样他就默认注入了。
于是我把代码改成如下形式,注入成功了。
@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;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持天达云。