Spring框架提供了各种PostProcessor的接口,作为容器或者Bean的后置处理器,其实这些PostProcessor本省也是需要注册到容器总的bean,里面定义的方法会在特定的时期呗容器所调用。
通过这种机制框架自身或者开发者再不改变容器或者Bean核心逻辑的的情况下对进行扩展或者定义。 比如包装Bean,影响他的行为,修改他的内容。
PostProcessor的种类
1.BeanDefinitionRegistryPostProcessor
即BeanDefinitionRegistry的后置处理器
2.BeanFactoryPostProcessor
简单容器的后置处理器
3.BeanPostProcessor
BeanDefinitionRegistryPostProcessor
根据注释说明,可以在正常的BeanFactoryPostProcessor检测之前注册更多的 BeanDefinition
测试
@Configuration
public class CustomizedBeanDefinitionRegistryPostProcessor implements BeanDefinitionRegistryPostProcessor {
@Override
public void postProcessBeanDefinitionRegistry(BeanDefinitionRegistry registry) throws BeansException {
//多注册一个user的Bean
Class<User> userClass = User.class;
BeanDefinitionBuilder builder = BeanDefinitionBuilder.genericBeanDefinition(userClass);
GenericBeanDefinition definition = (GenericBeanDefinition) builder.getRawBeanDefinition();
registry.registerBeanDefinition("divUser",definition);
}
@Override
public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
}
}
然后运行启动类
是可以获取到User的。
因此我们可以利用这种能力,去实现搜索某些第三方的class,然后注册进容器里面,MyBatis就是这么做的。
BeanFactoryPostProcessor
根据注释可以明白,主要影响容器里面的行为。
BeanPostProcessor
@Configuration
public class CustomizedBeanPostProcessor implements BeanPostProcessor {
//Bean初始化之前调用
@Override
public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
System.out.println(beanName+"调用了postProcessBeforeInitialization");
return bean;
}
//初始化之后
@Override
public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
System.out.println(beanName+"调用了"+"postProcessAfterInitialization");
return bean;
}
}
这样子写了之后,再容器初始化每个Bean的时候,都会处理这样的逻辑。
因此我们可以利用这个能力对Bean包装一些通用的逻辑包装。这不就是AOP吗?