该方式注入称之为获取器注入 ,他把一个方法声明为返回某种类型的bean,但实际返回的bean是在配置文件里面返回的,此方法可以用在设计具有可插拔的功能上,解除程序依赖,示例如下:
bean的声明:
public abstract class Man {
public abstract void showMe();
}
Teacher和Student是Man的两种不同实现:
public class Teacher extends Man {
@Override
public void showMe() {
System.out.println("I'm a teacher");
}
}
public class Student extends Man {
@Override
public void showMe() {
System.out.println("I'm a student");
}
}
现在我需要有种Man去实现我的服务类的方法:
public abstract class GenericBeanTest {
public void showMe(){
this.getMan().showMe();
}
public abstract Man getMan();
}
我不关心哪个Man去执行,只要是个Man就行
配置文件如下:
<?xml version="1.0" encoding="UTF-8"?>
<!-- Configures the Camel Context-->
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
">
<!--
<bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
<property name="username" value="[email protected]"/>
<property name="password" value="zaijian04551"/>
<property name="host" value="smtp.163.com"/>
</bean>
-->
<bean id="student" class="Helison.Student"/>
<bean id="teacher" class="Helison.Teacher"/>
<bean id="gernericTest" class="Helison.GenericBeanTest">
<lookup-method name="getMan" bean="teacher"/>
</bean>
</beans>
public class Main {
public static void main (String[] args){
ApplicationContext context=new FileSystemXmlApplicationContext("F:\\spring-learn\\src\\main\\java\\resources\\META-INF\\spring\\camel-context.xml");
GenericBeanTest test= (GenericBeanTest) context.getBean("gernericTest");
test.showMe();
}
}
结果:
在该示例程序中,服务类GernericTest里面的getBean方法不要求是抽象的,你可以给他一个实现,但是你如果在配置文件里面声明了lookup method的话在运行时就会替换成lookupmethod指明的那个bean
你甚至可以声明多个方法,在配置文件中声明多个lookup method去运行时替换