博客
关于我
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中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>