postProcessBeanFactory后处理beanFactory。时机是在所有的beanDenifition加载完成之后,bean实例化之前执行。比如,在beanfactory加载完成所有的bean后,想修改其中某个bean的定义,或者对beanFactory做一些其他的配置,就可以用此方法。在系列文章中,可以实现ClassPathXmlApplicationContext类并重写postProcessBeanFactory即可。
注:此功能和实现BeanFactoryPostProcessor的postProcessBeanFactory方法类似,可以做同样的功能。
默认情况下此方法是空的。需要子类去实现。下面是一个例子:
这里偷个懒拿自定义标签做一个例子
xml配置
<myTag:user id="test" userName="name" email="xxxx@qq.com"/>
测试:
ClassPathXmlApplicationContext context=
new ClassPathXmlApplicationContext("classpath:APP/CONTEXT/applicationContext-text.xml") ;
User user=(User)context.getBean("test");
System.out.println("username:"+user.getUserName()+":"+"email:"+user.getEmail());
运行结果为:
username:name:email:xxxx@qq.com
在不改配置文件的情况下我想修改username的值,怎么做呢?
就像上面说的写个java类去继承ClassPathXmlApplicationContext重写postProcessBeanFactory方法。
class MyApplicationContext extends ClassPathXmlApplicationContext{
public MyApplicationContext(String s){
super(s);
}
@Override
protected void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) {
BeanDefinition beanDefinition = beanFactory.getBeanDefinition("test");
PropertyValue propertyValue=new PropertyValue("userName", "小陈");
beanDefinition.getPropertyValues().addPropertyValue(propertyValue);
}
}
至于postProcessBeanFactory内的代码不陌生吧,在解析标签的时候就是通过PropertyValue把属性写到beanDefinition中的。
逻辑很简单,得到beanName为test的beanDefinition, 为其新增一个属性,但是这个属性的名字已经存在过了,所以会覆盖。
测试代码:
MyApplicationContext context=new MyApplicationContext("classpath:APP/CONTEXT/applicationContext-text.xml");
User user=(User)context.getBean("test");
System.out.println("username:"+user.getUserName()+":"+"email:"+user.getEmail());
测试结果:
username:小陈:email:xxxx@qq.com
这就做到了修改属性的作用。其实这里可以做的不止这些,beanFactory都得到了,还有什么不能干的呢。
转自 https://blog.csdn.net/cgj296645438/article/details/80119319