SpringMvc的数据绑定流程
在SpringMvc中会将来自web页面的请求和响应数据与controller中对应的处理方法的入参进行绑定,即数据绑定。流程如下:
-1.SpringMvc主框架将ServletRequest对象及目标方法的入参实例传递给WebDataBinderFactory实例,以创建DataBinder实例对象
-2.DataBinder对象调用装配在SpringMvc上下文中的ConversionService组件进行数据类型转换,数据格式化工作,将Servlet中的请求信息填充到入参对象中。
-3.调用Validator组件对已经绑定了请求消息的入参对象进行数据合法性校验,并最终生成数据绑定结果BindingData对象
-4.SpringMvc抽取BindingResult中的入参对象和校验错误对象,将它们赋给处理方法的相应入参。
总结起来:大致流程是 绑定(bindingResult)--》数据转换(conversionService)--》校验(validators)
数据转换
SpringMvc上下文中内建了很多转换器,可以完成大多数Java类型转换工作。但是如果就要转换成我们自定义的类型时,那么我们就要自定义类型转换器,并将其加入到conversionService中去,conversionService中包含了很多SpringMvc内建的转换器。
ConversionService是SpringMvc类型转换体系的核心接口,可以利用ConversionServiceFactoryBean在Spring的IOC容器中定义一个ConversionService,Spring将自动识别出IOC容器中的ConversionService,并在bean属性配置及SpringMvc处理方法入参绑定等场合使用它进行数据转换。
首先,定义一个转换器:
1 2 3 4 5 6 | public class Department { private Integer id; private String departmentName; ........... } |
1 2 3 4 5 6 7 8 9 10 11 | public class Employee { private Integer id; private String name; private String email; private Integer gender; private Department department; private Date birth; private double salary; ...... } |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | package com.seven.converts; import com.seven.domain.Department; import com.seven.domain.Employee; import org.springframework.core.convert.converter.Converter; import org.springframework.stereotype.Component; /** * Created by hu on 2016/4/3. */ @Component //该类的主要目的是将字符串转换为一个Employee对象 public class EmployeeConverts implements Converter<String,Employee> { @Override /* * source就是前台web页面传递过来的字符串 * 如:gg-gg@qq.com-0-105 姓名-邮件-性别-部门ID * */ public Employee convert(String source) { if (source!= null ){ String[] vals=source.split( "-" ); //获得雇员的姓名 String name=vals[ 0 ]; //获得雇员的邮件 String email=vals[ 1 ]; //获得雇员的性别 Integer gender=Integer.parseInt(vals[ 2 ]); //获得雇员的部门 Department department= new Department(); department.setId(Integer.parseInt(vals[ 3 ])); Employee employee= new Employee( null ,department,gender,email,name); return employee; } //如果字符串为空,就不生成雇员对象 return null ; } } |
在SpringMvc的配置文件中配置转换器:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | <? xml version="1.0" encoding="UTF-8"?> < beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!--配置自动扫描的包--> < context:component-scan base-package="com.seven"></ context:component-scan > <!--配置视图解析器,将视图逻辑名解析为/WEB-INF/pages/<viewName>.jsp--> < bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> < property name="prefix" value="/WEB-INF/pages/"/> < property name="suffix" value=".jsp"/> </ bean > <!--将自定义的转换器加入到框架中--> < bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean"> < property name="converters"> < set > < bean class="com.seven.converts.EmployeeConverts"/> </ set > </ property > </ bean > < mvc:annotation-driven /> < mvc:default-servlet-handler /> </ beans > |
Spring支持三种类型的转换器接口,实现任意一个转换器接口都可以作为自定义转换器注册ConversionServiceFactoryBean中:
-Converter<S,T>:将S类型的对象转为T类型对象
-ConverterFactory:将相同系列多个"同质"Converter封装在仪器,如果希望将一种类型的对象转换为一种类型及其子类的对象(例如将String转化为Number及Number的子类)
-GenericConverter:会根据源类对象与目标类对象所在的宿主类中的上下文信息进行类型转换。<mvc:annotation-driven conversion-service="conversionService"/>会将自定义的ConversionService注册到SpringMvc的上下文中去。
关于mvc:annotation-driven
<mvc:annotation-driven/>会自动注册ReuqestMappingHandlerMapping、ReuqestMappingHandlerHandler、ExceptionHanderExceptionResolver三个bean。还提供以下支持:
-支持使用ConversionService实例对表单参数进行类型转换
-支持使用@NumberFormat annotation @DateTimeFormat 注解完成数据类型的格式化
-支持使用@Valid注解对JavaBean实例进行JSR303验证
-支持使用@RequestBody 和@ResponseBody注解
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步