spring源码-BeanFactoryPostProcessor-3.2
一、BeanFactoryPostProcessor这个是spring容器的拓展之一,其目的是在容器初始化完成之前,通过beanFactory对上下文进行进行操作。
二、常用场景,需要对beanDefinition做处理,提供获取bean的方式。基本上涉及到的容器的加载修改,都可以操作。
三、实现方式
public class TestBeanFactoryPostProcessor implements BeanFactoryPostProcessor { //这里是要求必须实现的,也是我们操作的地方
@Override
public void postProcessBeanFactory(ConfigurableListableBeanFactory configurableListableBeanFactory) throws BeansException { }
}
说明:这里的ConfigurableListableBeanFactory 也就是我们初始化中用到的DefaultListableBeanFactory
四、源码实现
1)在容器初始化的refresh中实现的方式是
//beanFactory的后置操作
this.invokeBeanFactoryPostProcessors(beanFactory);
2)invokeBeanFactoryPostProcessors
protected void invokeBeanFactoryPostProcessors(ConfigurableListableBeanFactory beanFactory) {
Set<String> processedBeans = new HashSet();
Iterator var9;
ArrayList orderedPostProcessors;
//这里判断是否是DefaultListableBeanFactory的接口
if (beanFactory instanceof BeanDefinitionRegistry) {
BeanDefinitionRegistry registry = (BeanDefinitionRegistry)beanFactory;
List<BeanFactoryPostProcessor> regularPostProcessors = new LinkedList();
List<BeanDefinitionRegistryPostProcessor> registryPostProcessors = new LinkedList();
//获取初始化是否就存在BeanFactoryPostProcessor的类型
Iterator var7 = this.getBeanFactoryPostProcessors().iterator(); BeanDefinitionRegistryPostProcessor postProcessor;
while(var7.hasNext()) {
BeanFactoryPostProcessor postProcessor = (BeanFactoryPostProcessor)var7.next();
//如果是BeanDefinitionRegistryPostProcessor注册类型的调用postProcessBeanDefinitionRegistry
if (postProcessor instanceof BeanDefinitionRegistryPostProcessor) {
postProcessor = (BeanDefinitionRegistryPostProcessor)postProcessor;
//主要是注册bean的方式,这个是BeanFactoryPostProcessor的子接口
postProcessor.postProcessBeanDefinitionRegistry(registry);
registryPostProcessors.add(postProcessor);
} else {
//不是BeanDefinitionRegistryPostProcessor类型的直接放入regularPostProcessors
regularPostProcessors.add(postProcessor);
}
} //这里通过getBeansOfType方式加载继承BeanDefinitionRegistryPostProcessor方式的所有bean
Map<String, BeanDefinitionRegistryPostProcessor> beanMap = beanFactory.getBeansOfType(BeanDefinitionRegistryPostProcessor.class, true, false);
orderedPostProcessors = new ArrayList(beanMap.values());
//根据@Order进行排序
OrderComparator.sort(orderedPostProcessors);
var9 = orderedPostProcessors.iterator(); while(var9.hasNext()) {
postProcessor = (BeanDefinitionRegistryPostProcessor)var9.next();
//执行相关操作
postProcessor.postProcessBeanDefinitionRegistry(registry);
}
//这里执行对应的后置beanFactory后置操作
this.invokeBeanFactoryPostProcessors(registryPostProcessors, beanFactory);
this.invokeBeanFactoryPostProcessors(orderedPostProcessors, beanFactory);
this.invokeBeanFactoryPostProcessors(regularPostProcessors, beanFactory);
//添加BeanDefinitionRegistryPostProcessor的bean
processedBeans.addAll((Collection)beanMap.keySet());
} else {
//如果不是DefaultListableBeanFactory(当然还有其他类型)
this.invokeBeanFactoryPostProcessors(this.getBeanFactoryPostProcessors(), beanFactory);
} //这里才是重点,主要是实现BeanFactoryPostProcessor的接口bean
String[] postProcessorNames = beanFactory.getBeanNamesForType(BeanFactoryPostProcessor.class, true, false);
List<BeanFactoryPostProcessor> priorityOrderedPostProcessors = new ArrayList();
//这里分两种,一中是有序的一中是无序的
List<String> orderedPostProcessorNames = new ArrayList();
List<String> nonOrderedPostProcessorNames = new ArrayList();
String[] var10 = postProcessorNames;
int var19 = postProcessorNames.length; for(int var18 = 0; var18 < var19; ++var18) {
String ppName = var10[var18];
if (!processedBeans.contains(ppName)) {
//匹配对应排序
if (this.isTypeMatch(ppName, PriorityOrdered.class)) {
priorityOrderedPostProcessors.add((BeanFactoryPostProcessor)beanFactory.getBean(ppName, BeanFactoryPostProcessor.class));
} else if (this.isTypeMatch(ppName, Ordered.class)) {
orderedPostProcessorNames.add(ppName);
} else {
//一般使用无序的操作
nonOrderedPostProcessorNames.add(ppName);
}
}
} //有序的操作
OrderComparator.sort(priorityOrderedPostProcessors);
this.invokeBeanFactoryPostProcessors(priorityOrderedPostProcessors, beanFactory);
orderedPostProcessors = new ArrayList();
var9 = orderedPostProcessorNames.iterator(); while(var9.hasNext()) {
String postProcessorName = (String)var9.next();
orderedPostProcessors.add((BeanFactoryPostProcessor)this.getBean(postProcessorName, BeanFactoryPostProcessor.class));
} OrderComparator.sort(orderedPostProcessors);
this.invokeBeanFactoryPostProcessors(orderedPostProcessors, beanFactory); //无序的BeanFactoryPostProcessor操作
List<BeanFactoryPostProcessor> nonOrderedPostProcessors = new ArrayList();
Iterator var23 = nonOrderedPostProcessorNames.iterator(); while(var23.hasNext()) {
String postProcessorName = (String)var23.next();
nonOrderedPostProcessors.add((BeanFactoryPostProcessor)this.getBean(postProcessorName, BeanFactoryPostProcessor.class));
} this.invokeBeanFactoryPostProcessors(nonOrderedPostProcessors, beanFactory);
} //执行BeanFactoryPostProcessor结构中的postProcessBeanFactory方法
private void invokeBeanFactoryPostProcessors(Collection<? extends BeanFactoryPostProcessor> postProcessors, ConfigurableListableBeanFactory beanFactory) {
Iterator var4 = postProcessors.iterator(); while(var4.hasNext()) {
BeanFactoryPostProcessor postProcessor = (BeanFactoryPostProcessor)var4.next();
//实现BeanFactoryPostProcessor的方法可以通过beanFactory进行操作
postProcessor.postProcessBeanFactory(beanFactory);
} }
3)getBeanNamesForType
public String[] getBeanNamesForType(Class type, boolean includeNonSingletons, boolean allowEagerInit) {
List<String> result = new ArrayList();
//获取beanName
String[] beanDefinitionNames = this.getBeanDefinitionNames();
String[] var9 = beanDefinitionNames;
int var8 = beanDefinitionNames.length; for(int var7 = 0; var7 < var8; ++var7) {
String beanName = var9[var7];
//检查是否是别名
if (!this.isAlias(beanName)) {
try {
//获取BeanDefinition
RootBeanDefinition mbd = this.getMergedLocalBeanDefinition(beanName);
if (!mbd.isAbstract() && (allowEagerInit || (mbd.hasBeanClass() || !mbd.isLazyInit() || this.allowEagerClassLoading) && !this.requiresEagerInitForType(mbd.getFactoryBeanName()))) {
boolean isFactoryBean = this.isFactoryBean(beanName, mbd);
boolean matchFound = (allowEagerInit || !isFactoryBean || this.containsSingleton(beanName)) && (includeNonSingletons || this.isSingleton(beanName)) && this.isTypeMatch(beanName, type);
if (!matchFound && isFactoryBean) {
beanName = "&" + beanName;
//查看是否匹配
matchFound = (includeNonSingletons || mbd.isSingleton()) && this.isTypeMatch(beanName, type);
} if (matchFound) {
result.add(beanName);
}
}
} catch (CannotLoadBeanClassException var13) {
if (allowEagerInit) {
throw var13;
} if (this.logger.isDebugEnabled()) {
this.logger.debug("Ignoring bean class loading failure for bean '" + beanName + "'", var13);
} this.onSuppressedException(var13);
} catch (BeanDefinitionStoreException var14) {
if (allowEagerInit) {
throw var14;
} if (this.logger.isDebugEnabled()) {
this.logger.debug("Ignoring unresolvable metadata in bean definition '" + beanName + "'", var14);
} this.onSuppressedException(var14);
}
}
} //查看单例中是否存在
String[] singletonNames = this.getSingletonNames();
String[] var18 = singletonNames;
int var17 = singletonNames.length; for(var8 = 0; var8 < var17; ++var8) {
String beanName = var18[var8];
if (!this.containsBeanDefinition(beanName)) {
if (this.isFactoryBean(beanName)) {
//查看是否匹配
if ((includeNonSingletons || this.isSingleton(beanName)) && this.isTypeMatch(beanName, type)) {
result.add(beanName);
continue;
} beanName = "&" + beanName;
} if (this.isTypeMatch(beanName, type)) {
result.add(beanName);
}
}
} return StringUtils.toStringArray(result);
} public String[] getBeanDefinitionNames() {
Map var1 = this.beanDefinitionMap;
//这里的锁,主要是方式新的bean加入进来
synchronized(this.beanDefinitionMap) {
return this.frozenBeanDefinitionNames != null ? this.frozenBeanDefinitionNames : StringUtils.toStringArray(this.beanDefinitionNames);
}
} public boolean isTypeMatch(String name, Class targetType) throws NoSuchBeanDefinitionException {
String beanName = this.transformedBeanName(name);
Class typeToMatch = targetType != null ? targetType : Object.class;
//在单例中获取
Object beanInstance = this.getSingleton(beanName, false);
if (beanInstance != null) {
if (beanInstance instanceof FactoryBean) {
if (!BeanFactoryUtils.isFactoryDereference(name)) {
Class type = this.getTypeForFactoryBean((FactoryBean)beanInstance);
return type != null && typeToMatch.isAssignableFrom(type);
} else {
return typeToMatch.isAssignableFrom(beanInstance.getClass());
}
} else {
return !BeanFactoryUtils.isFactoryDereference(name) && typeToMatch.isAssignableFrom(beanInstance.getClass());
}
} else if (this.containsSingleton(beanName) && !this.containsBeanDefinition(beanName)) {
return false;
} else {
BeanFactory parentBeanFactory = this.getParentBeanFactory();
if (parentBeanFactory != null && !this.containsBeanDefinition(beanName)) {
return parentBeanFactory.isTypeMatch(this.originalBeanName(name), targetType);
} else {
//通过BeanDefinitionHolder方式判定
RootBeanDefinition mbd = this.getMergedLocalBeanDefinition(beanName);
BeanDefinitionHolder dbd = mbd.getDecoratedDefinition();
Class type;
if (dbd != null && !BeanFactoryUtils.isFactoryDereference(name)) {
RootBeanDefinition tbd = this.getMergedBeanDefinition(dbd.getBeanName(), dbd.getBeanDefinition(), mbd);
type = this.predictBeanType(dbd.getBeanName(), tbd, FactoryBean.class, typeToMatch);
if (type != null && !FactoryBean.class.isAssignableFrom(type)) {
//判断是否匹配
return typeToMatch.isAssignableFrom(type);
}
} Class beanClass = this.predictBeanType(beanName, mbd, FactoryBean.class, typeToMatch);
if (beanClass == null) {
return false;
} else if (FactoryBean.class.isAssignableFrom(beanClass)) {
if (!BeanFactoryUtils.isFactoryDereference(name)) {
//通过bean类型进行判断
type = this.getTypeForFactoryBean(beanName, mbd);
return type != null && typeToMatch.isAssignableFrom(type);
} else {
return typeToMatch.isAssignableFrom(beanClass);
}
} else {
return !BeanFactoryUtils.isFactoryDereference(name) && typeToMatch.isAssignableFrom(beanClass);
}
}
}
}
五、说明(源码部分解说,比较简单。主要是实现过程不复杂,主要是其中的操作,太多了)
1、BeanFactoryPostProcessor的后置beanFactroy处理主要是在refresh的this.invokeBeanFactoryPostProcessors(beanFactory);上面完成的。
2、在invokeBeanFactoryPostProcessors中是处理的BeanFactoryPostProcessor的子接口BeanDefinitionRegistryPostProcessor的postProcessBeanDefinitionRegistry方法。
3、在BeanFactoryPostProcessor的使用过程中使用了2中排序方式PriorityOrder和Order的方式
4、通过beanFactory的getBeanNamesForType方法,匹配实现BeanFactoryPostProcessor的bean.
5、在getBeanNamesForType中isTypeMatch是主要匹配类型的关键。
6、总体来说就是xml解析完成过后,进行的后置beanFactory的处理。
spring源码-BeanFactoryPostProcessor-3.2的更多相关文章
- spring源码分析系列 (5) spring BeanFactoryPostProcessor拓展类PropertyPlaceholderConfigurer、PropertySourcesPlaceholderConfigurer解析
更多文章点击--spring源码分析系列 主要分析内容: 1.拓展类简述: 拓展类使用demo和自定义替换符号 2.继承图UML解析和源码分析 (源码基于spring 5.1.3.RELEASE分析) ...
- spring源码分析系列 (1) spring拓展接口BeanFactoryPostProcessor、BeanDefinitionRegistryPostProcessor
更多文章点击--spring源码分析系列 主要分析内容: 一.BeanFactoryPostProcessor.BeanDefinitionRegistryPostProcessor简述与demo示例 ...
- Spring源码解读之BeanFactoryPostProcessor的处理
前言 前段时间旁听了某课堂两节Spring源码解析课,刚好最近自己又在重新学习中,便在这里记录一下学习所得.我之前写过一篇博文,是介绍BeanFactoryPostProcessor跟BeanPost ...
- Spring源码分析之`BeanFactoryPostProcessor`调用过程
前文传送门: Spring源码分析之预启动流程 Spring源码分析之BeanFactory体系结构 本文内容: AbstractApplicationContext#refresh前部分的一点小内容 ...
- Spring源码解析之BeanFactoryPostProcessor(三)
在上一章中笔者介绍了refresh()的<1>处是如何获取beanFactory对象,下面我们要来学习refresh()方法的<2>处是如何调用invokeBeanFactor ...
- Spring源码分析-BeanFactoryPostProcessor
Spring源码分析-BeanFactoryPostProcessor 博主技术有限,本文难免有错误的地方,如果您发现了欢迎评论私信指出,谢谢 BeanFactoryPostProcessor接口是S ...
- Spring源码之BeanFactoryPostProcessor(后置处理器)
Spring源码之BeanFactoryPostProcessor(后置处理器). 有点水平的Spring开发人员想必都知道BeanFactoryPostProcessor也就是常说的后置管理器,这是 ...
- spring源码:学习线索(li)
一.spring xml配置(不包括AOP,主要了解在初始化及实例化过程中spring配置文件中每项内容的具体实现过程,从根本上掌握spring) <bean>的名字 &,alia ...
- spring源码 — 一、IoC容器初始化
IoC容器初始化 注意:本次的spring源码是基于3.1.1.release版本 容器:具有获取Bean功能--这是最基本功能,也是BeanFactory接口定义的主要行为,在添加了对于资源的支持之 ...
- Spring源码情操陶冶-AbstractApplicationContext#invokeBeanFactoryPostProcessors
阅读源码有利于陶冶情操,承接前文Spring源码情操陶冶-AbstractApplicationContext#postProcessBeanFactory 约定:web.xml中配置的context ...
随机推荐
- boost tss.hpp源码分析
tss.hpp定义了thread_specific_ptr,使用thread local storage 技术 1.在thread目录下的win32和pthread目录下thread_data.hpp ...
- 9.spring:事务管理(下):声明式事务管理
声明式事务管理 sprin的声明式事务是管理AOP技术实现的事务管理,其本质是是对方法前后进行拦截,然后 在目标方法开始之前创建或者加入一个事务,在执行完成目标方法之后根据执行情况提交或者回滚事务. ...
- mac 删除自带 ABC 输入法的方法
首先需要关闭 mac 系统的 SIP ,不然删不掉,不会关的可以查看我的另一篇文章:mac 关闭系统完整性保护 SIP(System Integrity Protection)的方法 . 关闭 SIP ...
- Multicast Routing
Multicasting Source S sends packets to multicast group G1 (and minimize the number of copies) Revers ...
- Tag It 一款 Jquery控件,当你在文本框中输入逗号时,自动帮你分隔开相关内容
Demo地址:http://webspirited.com/tagit/ 使用方法: 除了JQuery脚本外,下面的脚本也是必须的,这些脚本你都可以去GitHub下载:https://github.c ...
- 微信小程序开发——进阶篇
由于项目的原因,最近的工作一直围绕着微信小程序.现在也算告一段落,是时候整理一下这段时间的收获了.我维护的小程序有两个,分别是官方小程序和一个游戏为主的小程序.两个都是用了wepy进行开发,就是这个: ...
- sql1999语法
1.交叉连接 cross join 左右两个表进行组合,产生笛卡尔积累. 左边每一行分别于右表每一行数据匹配. 2.using using使用的前提是两个表右关联的字段需要对应,两个表的join查询. ...
- Swift_销毁
Swift_销毁 点击查看源码 销毁 func test() { class SomeClass { //类销毁时 通知此方法 deinit { print("销毁") } } v ...
- ES5 实现 ES6 的 class以及extends
ts中是这样的 class Greeter { greeting:string; constructor(message:string){ this.greeting = message; } gre ...
- [译文][转载]greenlet:轻量级并发程序
英文原文地址:https://greenlet.readthedocs.io/en/latest/中文翻译转载地址:https://zhuanlan.zhihu.com/p/25188731 背景 g ...