实现BeanFactoryAware接口的Bean,拥有访问BeanFactory容器的能力,实现BeanFactoryAware接口的Bean实例被容器创建后,它会拥有一个引用,该引用指向创建它的BeanFactory。
BeanFactoryAware接口只有一个方法:setBeanFactory(BeanFactory beanFactory) 该方法有一个参数beanFactory,该参数指向创建它的BeanFactory。
PS:以前我们定义一个setter方法时,通常都是由程序员来调用的,setter方法参数也由程序员指定;即使使用Spring容器依赖注入时,setter方法参数值还是由程序员通过配置文件来指定。但此处的这个setter方法将由Spring调用,Spring调用该方法时将Spring容器作为参数传入该方法。与该接口类似的还有ApplicationContextAware、BeanNameAware和ResourceLoaderAware等接口,这些接口里都会提供类似的setter方法,这些方法也由Spring负责调用。
实现ApplicationContextAware接口的类
package demo;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
public class Chinese implements ApplicationContextAware {
//将BeanFactory容器以成员变量保存
private ApplicationContext ctx;
@Override
public void setApplicationContext(ApplicationContext ctx)
throws BeansException {
// TODO Auto-generated method stub
this.ctx=ctx;
}
//获得ApplicationContext的测试方法
public ApplicationContext getContext(){
return ctx;
}
}
将该Bean部署在Spring容器中,部署该Bean与部署其他Bean没有任何区别。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.springframework.org/schema/beans"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd"
>
<bean id="chinese" class="demo.Chinese"/>
</beans>
测试
package demo;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Test {
public static void main(String[] args) {
ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
Chinese p = ctx.getBean("chinese",Chinese.class);
System.out.println(p.getContext());
//比较两种方法获得的BeanFactory
System.out.println(ctx==p.getContext());
}
}
结果
实现ApplicationContextAware接口让Bean拥有了访问容器的能力,但污染了代码,导致代码与Spring接口耦合在一起。因此,如果不是特别必要,建议不要直接访问容器。