在方法参数上使用@ModelAttribute代表参数的值须要从model中获取。若是model不存在,参数应当首先被实例化而后添加进model。一旦model存在,参数的属性须要从名称匹配的请求参数中获取。java
示例
app
@RequestMapping(value="/owners/{ownerId}/pets/{petId}/edit", method=RequestMethod.POST) public String processSubmit(@ModelAttribute Pet pet){ }
上面示例中pet实例的来源,有如下几种状况:
可能已经存在因为使用了@SessionAttributes。
因为在同一个控制器中的@ModelAttribute方法。
可能基于URI模板变量和类型转换器检索。
可能有默认的构造函数实例化。函数
@ModelAttribute方法是一种获取经过使用@SessionAttributes存储在请求中的属性普通方式。在某些状况下经过使用URI模板变量和类型转换器检索属性会更方便。code
示例
orm
@RequestMapping(value="/account/{account}", method=RequestMethod.PUT) public String save(@ModelAttribute("account") Account account){}
示例中model属性与URI模板变量名相匹配。若是注册了能够将String类型的account值转换为Account实例的Converter<String, Account>,上面的示例能够不须要@ModelAttribute方法。字符串
下一步是数据绑定。WebDataBinder类将表单域和字符串参数按照名字与model属性匹配。
匹配的域会进过必要的类型转换。it
数据绑定过程当中可能会产生缺乏必须的域或类型转换等错误。在紧跟@ModelAttribute参数添加BindingResult参数来检查此类错误。io
示例
模板
@RequestMapping(value="/owners/{ownerId}/pets/{petId}/edit", method=RequestMethod.POST) public String processSubmit(@ModelAttribute("pet") Pet pet, BindResult result){ if(result.hasErrors()){ retrun "petForm"; } }
经过BindResult能够检查是否存在错误。经过使用Spring的errors表单标签显示错误。
在数据绑定中能够经过BindingResult使用自定义的校验器来记录数据绑定错误。这样能够将数据绑定错误存放在一个地方反馈给用户。class
示例
@RequestMapping(value="/owners/{ownerId}/pets/{petId}/edit", method=RequestMethod.POST) public String processSubmit(@ModelAttribute("pet") Pet pet, BindingResult result){ new PetValidator().validate(pet, reult); if(result.hasErrors){ return "petForm"; } }
或者经过添加JSR-303@Valid注解自动校验。