博客
关于我
spring5.1.x源码解析之四(自定义属性编辑器执行逻辑)
阅读量:637 次
发布时间:2019-03-13

本文共 5565 字,大约阅读时间需要 18 分钟。

文章目录

默认属性编辑器

这段代码的意思就设置默认属性编辑器

protected void prepareBeanFactory(ConfigurableListableBeanFactory beanFactory) {   	...		//设置默认属性编辑器		//registerBeanPostProcessors会注册所有自定义编辑器,对应AbstractBeanFactory.customEditors		//AbstractBeanFactory.initBeanWrapper会使用编辑器,对应AbstractBeanFactory.propertyEditorRegistrars		beanFactory.addPropertyEditorRegistrar(new ResourceEditorRegistrar(this, getEnvironment()));...	}

在初始化BeanWrapper的时候会注册属性编辑器到BeanWrapper中

/*org.springframework.beans.factory.support.AbstractBeanFactory#initBeanWrapper */	protected void initBeanWrapper(BeanWrapper bw) {   ...		//注册编辑器		registerCustomEditors(bw);	}
protected void registerCustomEditors(PropertyEditorRegistry registry) {   ...					//批量注册通用属性编辑器						if (registry instanceof PropertyEditorRegistrySupport) {   			((PropertyEditorRegistrySupport) registry).overrideDefaultEditor(requiredType, editor);		}...		}	}

执行到这里基本就注册到BeanWrapper中overriddenDefaultEditors属性了

public void overrideDefaultEditor(Class
requiredType, PropertyEditor propertyEditor) { if (this.overriddenDefaultEditors == null) { this.overriddenDefaultEditors = new HashMap<>(); } this.overriddenDefaultEditors.put(requiredType, propertyEditor); }

自定义属性编辑器方式一之直接注册

配置文件如下

自定义解析类

public class DatePropertyEditor extends PropertyEditorSupport {       private String format = "yyyy-MM-dd";    public void setFormat(String format) {           this.format = format;    }    @Override    public void setAsText(String text) throws IllegalArgumentException {           SimpleDateFormat simpleDateFormat = new SimpleDateFormat(format);        try {               Date parse = simpleDateFormat.parse(text);            this.setValue(parse);        } catch (ParseException e) {               e.printStackTrace();        }    }}

首先可以看到配置文件配置的CustomEditorConfigurer类继承了BeanFactoryPostProcessor接口,这个接口的意思就是生成bean之前首先执行这个接口里面postProcessBeanFactory方法

public class CustomEditorConfigurer implements BeanFactoryPostProcessor, Ordered {   @Override	public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {   		if (this.propertyEditorRegistrars != null) {   			for (PropertyEditorRegistrar propertyEditorRegistrar : this.propertyEditorRegistrars) {   				beanFactory.addPropertyEditorRegistrar(propertyEditorRegistrar);			}		}...	}}

当执行invokeBeanFactoryPostProcessors方法的时候,会查询所有的继承了BeanFactoryPostProcessor接口的postProcessBeanFactory方法

@Override	public void refresh() throws BeansException, IllegalStateException {   		...				// Invoke factory processors registered as beans in the context.				//激活各种BeanFactory处理器				//BeanFactoryPostProcessor作用域容器级,仅仅对容器中的bean进行后置处理,如propertyPlaceholderConfig,继承order可实现排序调用功能				//BeanFactoryPostProcessor可以修改实际的bean实例				invokeBeanFactoryPostProcessors(beanFactory);***	}

这个时候就会把配置文件配置了customEditors属性的值经过CustomEditorConfigurer类的postProcessBeanFactory方法,注册到BeanFactorycustomEditors属性,然后当执行registerCustomEditors的时候注册

/*	注册默认属性编辑器	注册自定义属性编辑器	 */	protected void registerCustomEditors(PropertyEditorRegistry registry) {   ...		//注册自定义属性编辑器		if (!this.customEditors.isEmpty()) {   			this.customEditors.forEach((requiredType, editorClass) ->					registry.registerCustomEditor(requiredType, BeanUtils.instantiateClass(editorClass)));		}	}

执行注册方法,注册到customEditors缓存中

@Override	public void registerCustomEditor(@Nullable Class
requiredType, @Nullable String propertyPath, PropertyEditor propertyEditor) { ... //注册自定义属性编辑器 if (this.customEditors == null) { this.customEditors = new LinkedHashMap<>(16); } this.customEditors.put(requiredType, propertyEditor); this.customEditorCache = null; ... }

自定义属性编辑器方式二之本地注册

配置文件

这里使用spring提供的解析器

public class DatePropertyEditorRegistry implements PropertyEditorRegistrar {       public void registerCustomEditors(PropertyEditorRegistry registry) {           registry.registerCustomEditor(Date.class,                new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"), true));    }}

用的还是CustomEditorConfigurer,只不过注入的属性是propertyEditorRegistrars,跟上述一样,执行的方法变了.会加载到BeanFactorypropertyEditorRegistrars属性中

@Override	public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {   		//注册		if (this.propertyEditorRegistrars != null) {   			for (PropertyEditorRegistrar propertyEditorRegistrar : this.propertyEditorRegistrars) {   				beanFactory.addPropertyEditorRegistrar(propertyEditorRegistrar);			}		}..	}

在初始化BeanWrapper的时候会执行以下方法

protected void registerCustomEditors(PropertyEditorRegistry registry) {   ...					//批量注册通用属性编辑器					registrar.registerCustomEditors(registry);...	}

然后调用我们自定义的类进行注册

public class DatePropertyEditorRegistry implements PropertyEditorRegistrar {       public void registerCustomEditors(PropertyEditorRegistry registry) {           registry.registerCustomEditor(Date.class,                new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"), true));    }}

执行注册方法,注册到customEditors缓存中

@Override	public void registerCustomEditor(@Nullable Class
requiredType, @Nullable String propertyPath, PropertyEditor propertyEditor) { ... //注册自定义属性编辑器 if (this.customEditors == null) { this.customEditors = new LinkedHashMap<>(16); } this.customEditors.put(requiredType, propertyEditor); this.customEditorCache = null; ... }

自定义属性编辑器方式三之自定义转换服务类

转载地址:http://mnwoz.baihongyu.com/

你可能感兴趣的文章
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>