Spring 框架提供了几种 PostProcessor 接口用于建模对容器或者bean的后置处理器,它们定义了一些方法,这些方法在特定的时机会被调用。通过这种机制,框架自身或者应用开发人员有机会在不侵入容器或者bean核心逻辑的情况下为容器或者bean做针对某些特定方面的定制或者扩展:能力增强,属性设置,内容修改,对象代理,甚至直接替换整个bean。
Spring 提供的 PostProcessor 接口有如下几种 :
-
BeanDefinitionRegistryPostProcessor–BeanDefinitionRegistry后置处理器 – 容器级别 -
BeanFactoryPostProcessor–BeanFactory后置处理器 – 容器级别 -
BeanPostProcessor–Bean后置处理器 – bean实例级别
实际应用中又可细分为如下几类 :
-
InstantiationAwareBeanPostProcessor
-
MergedBeanDefinitionPostProcessor
-
DestructionAwareBeanPostProcessor
-
SmartInstantiationAwareBeanPostProcessor
-
一般BeanPostProcessor
Spring 框架自身提供了很多这些 PostProcessor 的实现类,每个 PostProcessor 实现类分别有不同的关注点,Spring 利用这些 PostProcessor 实现类完成了很多框架自身的任务,主要在容器启动和 bean 获取阶段。另外,开发人员也可以实现自己的 PostProcessor 来扩展 Spring 容器或者 bean 的能力。这里面尤其是通过自定义实现 BeanPostProcessor , 开发人员有机会对容器中所有的 bean 做定制。
注意,本文中 PostProcessor 只是用于表达”后置处理器”这一概念,而并非 Spring 中存在一个使用此名字的接口或者类。
以上各种容器级别 PostProcessor 接口之间的继承关系:
graph BT;
BeanDefinitionRegistryPostProcessor-->BeanFactoryPostProcessor;
以上各种 bean 级别 BeanPostProcessor 接口之间的继承关系:
graph BT;
SmartInstantiationAwareBeanPostProcessor-->InstantiationAwareBeanPostProcessor;
InstantiationAwareBeanPostProcessor-->BeanPostProcessor;
MergedBeanDefinitionPostProcessor-->BeanPostProcessor;
DestructionAwareBeanPostProcessor-->BeanPostProcessor;
参考文章
Spring各种PostProcessor : BeanDefinitionRegistryPostProcessor
Spring各种PostProcessor : BeanFactoryPostProcessor
Spring各种PostProcessor : BeanPostProcessor