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 ...
随机推荐
- 移动端开发 rem 案例
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- java中的泛型2--注意的一些问题和面试题
前言 这里总结一下泛型中需要注意的一些地方和面试题,通过面试题可以让你掌握的更清楚一些. 泛型相关问题 1.泛型类型引用传递问题 在Java中,像下面形式的引用传递是不允许的: ArrayList&l ...
- NGSQC toolkit
一.NGSQCTooklit 使用 主要是去除dapter和低质量的碱基,并有统计结果 可以得到如下的结果 1,每个位置的碱基的平均质量 2,每个GC值对应的reads数 3,每个质量值对应的read ...
- Redis的Windows端开发连接Linux端以及相应的代码实现
在Windows端开发连接需要进行配置文件的配置: 在redis.conf配置文件中 将protected-mode yes,修改为protected-mode no:不保护redis # By de ...
- 播放WAV文件和系统提示音
- log4net快速使用流程
以下内容大部分来自这里,对原作者流子表示感谢 1.Nuget安装,当前版本2.0.8 2.创建log4net.config文件,文件内容如下: <?xml version="1.0&q ...
- Entity Framework——执行sql语句
EF版本:6.0.0 EF对大量数据或多表连接一次操作耗时较大,或要求响应时间尽可能小,因此采用EF框架执行SQL语句的方案 1DbContext.Database 这个类包含了大量的操作方法,见截图 ...
- 使用 input[type=file]上传文件
var $file = $('#file'); $('#btn').click(function() { var data = new FormData(); data.append('file', ...
- easy-im:一款基于netty的即时通讯系统
介绍 easy-im是面向开发者的一款轻量级.开箱即用的即时通讯系统,帮助开发者快速搭建消息推送等功能. 基于easy-im,你可以快速实现以下功能: + 聊天软件 + IoT消息推送 基本用法 项目 ...
- Swift_可选链
Swift_可选链 点击查看源码 //可选链 func test() { class Person { //可选属性可能为nil或Residence类 var residence: Residence ...