spring mvc 数据绑定总结

spring mvc 做web开发时,经常会不知道如何合适绑定页面数据.用惯struts2的朋友更认为spring mvc 绑定数据不如struts2方便(本人最开始也是这么认为),经过一段时间的应用和测试,总结出以下几种情况,希望对刚接触spring mvc 的朋友有所帮助.

示例程序下载

查看spring源码可以看出spring支持转换的数据类型已经很多了.

org.springframework.beans.PropertyEditorRegistrySupport.java

[java] view plaincopy

  1. /**
  2. * Actually register the default editors for this registry instance.
  3. */
  4. private void doRegisterDefaultEditors() {
  5. this.defaultEditors = new HashMap<Class, PropertyEditor>(64);
  6. // Simple editors, without parameterization capabilities.
  7. // The JDK does not contain a default editor for any of these target types.
  8. this.defaultEditors.put(Charset.class, new CharsetEditor());
  9. this.defaultEditors.put(Class.class, new ClassEditor());
  10. this.defaultEditors.put(Class[].class, new ClassArrayEditor());
  11. this.defaultEditors.put(Currency.class, new CurrencyEditor());
  12. this.defaultEditors.put(File.class, new FileEditor());
  13. this.defaultEditors.put(InputStream.class, new InputStreamEditor());
  14. this.defaultEditors.put(Locale.class, new LocaleEditor());
  15. this.defaultEditors.put(Pattern.class, new PatternEditor());
  16. this.defaultEditors.put(Properties.class, new PropertiesEditor());
  17. this.defaultEditors.put(Resource[].class, new ResourceArrayPropertyEditor());
  18. this.defaultEditors.put(TimeZone.class, new TimeZoneEditor());
  19. this.defaultEditors.put(URI.class, new URIEditor());
  20. this.defaultEditors.put(URL.class, new URLEditor());
  21. // Default instances of collection editors.
  22. // Can be overridden by registering custom instances of those as custom editors.
  23. this.defaultEditors.put(Collection.class, new CustomCollectionEditor(Collection.class));
  24. this.defaultEditors.put(Set.class, new CustomCollectionEditor(Set.class));
  25. this.defaultEditors.put(SortedSet.class, new CustomCollectionEditor(SortedSet.class));
  26. this.defaultEditors.put(List.class, new CustomCollectionEditor(List.class));
  27. this.defaultEditors.put(SortedMap.class, new CustomMapEditor(SortedMap.class));
  28. // Default editors for primitive arrays.
  29. this.defaultEditors.put(byte[].class, new ByteArrayPropertyEditor());
  30. this.defaultEditors.put(char[].class, new CharArrayPropertyEditor());
  31. // The JDK does not contain a default editor for char!
  32. this.defaultEditors.put(char.class, new CharacterEditor(false));
  33. this.defaultEditors.put(Character.class, new CharacterEditor(true));
  34. // Spring‘s CustomBooleanEditor accepts more flag values than the JDK‘s default editor.
  35. this.defaultEditors.put(boolean.class, new CustomBooleanEditor(false));
  36. this.defaultEditors.put(Boolean.class, new CustomBooleanEditor(true));
  37. // The JDK does not contain default editors for number wrapper types!
  38. // Override JDK primitive number editors with our own CustomNumberEditor.
  39. this.defaultEditors.put(byte.class, new CustomNumberEditor(Byte.class, false));
  40. this.defaultEditors.put(Byte.class, new CustomNumberEditor(Byte.class, true));
  41. this.defaultEditors.put(short.class, new CustomNumberEditor(Short.class, false));
  42. this.defaultEditors.put(Short.class, new CustomNumberEditor(Short.class, true));
  43. this.defaultEditors.put(int.class, new CustomNumberEditor(Integer.class, false));
  44. this.defaultEditors.put(Integer.class, new CustomNumberEditor(Integer.class, true));
  45. this.defaultEditors.put(long.class, new CustomNumberEditor(Long.class, false));
  46. this.defaultEditors.put(Long.class, new CustomNumberEditor(Long.class, true));
  47. this.defaultEditors.put(float.class, new CustomNumberEditor(Float.class, false));
  48. this.defaultEditors.put(Float.class, new CustomNumberEditor(Float.class, true));
  49. this.defaultEditors.put(double.class, new CustomNumberEditor(Double.class, false));
  50. this.defaultEditors.put(Double.class, new CustomNumberEditor(Double.class, true));
  51. this.defaultEditors.put(BigDecimal.class, new CustomNumberEditor(BigDecimal.class, true));
  52. this.defaultEditors.put(BigInteger.class, new CustomNumberEditor(BigInteger.class, true));
  53. // Only register config value editors if explicitly requested.
  54. if (this.configValueEditorsActive) {
  55. StringArrayPropertyEditor sae = new StringArrayPropertyEditor();
  56. this.defaultEditors.put(String[].class, sae);
  57. this.defaultEditors.put(short[].class, sae);
  58. this.defaultEditors.put(int[].class, sae);
  59. this.defaultEditors.put(long[].class, sae);
  60. }
  61. }

1.基本数据类型

很简单,该怎么写就怎么写.

controller代码

[java] view plaincopy

  1. @RequestMapping
  2. public void test1(String name, Integer age, Double income, Boolean isMarried, String[] interests)
  3. {
  4. System.out.println("简单数据类型绑定=========");
  5. System.out.println("名字:" + name);
  6. System.out.println("年龄:" + age);
  7. System.out.println("收入:" + income);
  8. System.out.println("已结婚:" + isMarried);
  9. System.out.println("兴趣:");
  10. for (String interest : interests)
  11. {
  12. System.out.println(interest);
  13. }
  14. System.out.println("====================");
  15. }

jsp代码

[xhtml] view plaincopy

  1. <form action="test1.do" method="post">
  2. <div class="f_left">姓名:</div>
  3. <div class="f_left"><input name="name" value="张三"/></div>
  4. <div class="clear"></div>
  5. <div class="f_left">年龄:</div>
  6. <div class="f_left"><input name="age" value="20"/></div>
  7. <div class="clear"></div>
  8. <div class="f_left">收入:</div>
  9. <div class="f_left"><input name="income" value="100000"/></div>
  10. <div class="clear"></div>
  11. <div class="f_left">结婚:</div>
  12. <div class="f_left">
  13. <input type="radio" name="isMarried" value="true" checked="checked"/>是
  14. <input type="radio" name="isMarried" value="false"/>否</div>
  15. <div class="clear"></div>
  16. <div class="f_left">兴趣:</div>
  17. <div class="f_left">
  18. <input type="checkbox" name="interests" value="听歌" checked="checked"/>听歌
  19. <input type="checkbox" name="interests" value="书法" checked="checked"/>书法
  20. <input type="checkbox" name="interests" value="看电影" checked="checked"/>看电影
  21. </div>
  22. <div class="clear"></div>
  23. <div><input type="submit" value="提交表单"/></div>
  24. </form>

2.简单对象类型

与基本类型相拟,只不过绑定到对象上更加简洁.(类拟struts的ActionForm)

controller代码

[java] view plaincopy

  1. @RequestMapping  
  2.     public void test2(User user)  
  3.     {  
  4.         System.out.println("简单对象类型绑定=========");  
  5.         System.out.println("名字:" + user.getName());  
  6.         System.out.println("年龄:" + user.getAge());  
  7.         System.out.println("收入:" + user.getIncome());  
  8.         System.out.println("已结婚:" + user.getIsMarried());  
  9.         System.out.println("========================");  
  10.     }  

 

user代码

[java] view plaincopy

  1. public class User {
  2. private String name;
  3. private Integer age;
  4. private Boolean isMarried;
  5. private Double income;
  6. private String[] interests;
  7. public String getName() {
  8. return name;
  9. }
  10. public void setName(String name) {
  11. this.name = name;
  12. }
  13. public Integer getAge() {
  14. return age;
  15. }
  16. public void setAge(Integer age) {
  17. this.age = age;
  18. }
  19. public Boolean getIsMarried() {
  20. return isMarried;
  21. }
  22. public void setIsMarried(Boolean isMarried) {
  23. this.isMarried = isMarried;
  24. }
  25. public Double getIncome() {
  26. return income;
  27. }
  28. public void setIncome(Double income) {
  29. this.income = income;
  30. }
  31. public String[] getInterests() {
  32. return interests;
  33. }
  34. public void setInterests(String[] interests) {
  35. this.interests = interests;
  36. }
  37. }

jsp代码

[xhtml] view plaincopy

  1. <form action="test2.do" method="post">  
  2.         <div class="f_left">姓名:</div>  
  3.         <div class="f_left"><input name="name" value="lxf"/></div>  
  4.         <div class="clear"></div>  
  5.         <div class="f_left">年龄:</div>  
  6.         <div class="f_left"><input name="age" value="20"/></div>  
  7.         <div class="clear"></div>  
  8.         <div class="f_left">收入:</div>  
  9.         <div class="f_left"><input name="income" value="100000"/></div>  
  10.         <div class="clear"></div>  
  11.         <div class="f_left">结婚:</div>  
  12.         <div class="f_left">  
  13.         <input type="radio" name="isMarried" value="true" checked="checked"/>是  
  14.         <input type="radio" name="isMarried" value="false"/>否</div>  
  15.         <div class="clear"></div>  
  16.         <div class="f_left">兴趣:</div>  
  17.         <div class="f_left">  
  18.         <input type="checkbox" name="interests" value="听歌" checked="checked"/>听歌  
  19.         <input type="checkbox" name="interests" value="书法" checked="checked"/>书法  
  20.         <input type="checkbox" name="interests" value="看电影" checked="checked"/>看电影  
  21.         </div>  
  22.         <div class="clear"></div>  
  23.         <div><input type="submit" value="提交表单"/></div>  
  24.     </form>  

 

3.List类型绑定

网上很多人都给不出答案,关键在于,List需要绑定在对象(ActionForm),直接写在request-mapping函数的参数是不行的,更重要的一点是要创建对象(ArrayList).

controller代码

[java] view plaincopy

  1. @RequestMapping
  2. public void test3(Club club)
  3. {
  4. System.out.println("list类型绑定=========");
  5. System.out.println("会员:");
  6. for (User user : club.getUsers())
  7. {
  8. System.out.println(user.getName());
  9. }
  10. System.out.println("========================");
  11. }

Club代码

[java] view plaincopy

  1. public class Club {
  2. private List<User> users = new ArrayList<User>();
  3. public List<User> getUsers() {
  4. return users;
  5. }
  6. public void setUsers(List<User> users) {
  7. this.users = users;
  8. }
  9. }

jsp代码

[xhtml] view plaincopy

  1. <form action="test3.do" method="post">
  2. <div class="f_left">会员1号:</div>
  3. <div class="f_left">
  4. <input name="users[0].name" value="张三"/>
  5. </div>
  6. <div class="clear"></div>
  7. <div class="f_left">会员2号:</div>
  8. <div class="f_left">
  9. <input name="users[1].name" value="李四"/>
  10. </div>
  11. <div class="clear"></div>
  12. <div class="f_left">会员3号:</div>
  13. <div class="f_left">
  14. <input name="users[2].name" value="王五"/>
  15. </div>
  16. <div class="clear"></div>
  17. <div><input type="submit" value="提交表单"/></div>
  18. </form>

4.Set类型绑定

与List类型相似,经测试表明,绑定Set数据时,必须先在Set对象中Add相应的数量的模型对象.

controller代码

[java] view plaincopy

  1. @RequestMapping
  2. public void test4(Club2 club)
  3. {
  4. System.out.println("set类型绑定=========");
  5. System.out.println("会员:");
  6. for (User user : club.getUsers())
  7. {
  8. System.out.println(user.getName());
  9. }
  10. System.out.println("========================");
  11. }

Club2代码

[java] view plaincopy

  1. public class Club2 {
  2. private Set<User> users = new LinkedHashSet<User>();
  3. public Club2() {
  4. users.add(new User());
  5. users.add(new User());
  6. users.add(new User());
  7. }
  8. public Set<User> getUsers() {
  9. return users;
  10. }
  11. public void setUsers(Set<User> users) {
  12. this.users = users;
  13. }
  14. }

jsp代码

[xhtml] view plaincopy

  1. <form action="test4.do" method="post">  
  2.         <div class="f_left">会员1号:</div>  
  3.         <div class="f_left">  
  4.         <input name="users[0].name" value="张三"/>  
  5.         </div>  
  6.         <div class="clear"></div>  
  7.         <div class="f_left">会员2号:</div>  
  8.         <div class="f_left">  
  9.         <input name="users[1].name" value="李四"/>  
  10.         </div>  
  11.         <div class="clear"></div>  
  12.         <div class="f_left">会员3号:</div>  
  13.         <div class="f_left">  
  14.         <input name="users[2].name" value="王五"/>  
  15.         </div>  
  16.         <div class="clear"></div>  
  17.         <div><input type="submit" value="提交表单"/></div>  
  18.     </form>  

 

5.Map类型绑定

最灵活的一种方式,可无限绑定未定义的参数,注意必须绑定在对象下(ActionForm).

controller代码

[java] view plaincopy

  1. @RequestMapping  
  2.     public void test5(UserForm userForm)  
  3.     {  
  4.         System.out.println("Map类型绑定=========");  
  5.         System.out.println("名字:" + userForm.getUser().get("name"));  
  6.         System.out.println("年龄:" + userForm.getUser().get("age"));  
  7.         System.out.println("收入:" + userForm.getUser().get("income"));  
  8.         System.out.println("已结婚:" + userForm.getUser().get("isMarried"));  
  9.         System.out.println("========================");  
  10.     }  

 

UserForm.java代码

[java] view plaincopy

  1. public class UserForm {  
  2.     private Map<String, String> userMap = new LinkedHashMap<String, String>();  
  3.     private User user = new User();  
  4.       
  5.     public Map<String, String> getUserMap() {  
  6.         return userMap;  
  7.     }  
  8.     public void setUserMap(Map<String, String> userMap) {  
  9.         this.userMap = userMap;  
  10.     }  
  11.     public User getUser() {  
  12.         return user;  
  13.     }  
  14.     public void setUser(User user) {  
  15.         this.user = user;  
  16.     }  
  17.       
  18. }  

 

jsp代码

[xhtml] view plaincopy

  1. <form action="test5.do" method="post">
  2. <div class="f_left">姓名:</div>
  3. <div class="f_left"><input name="user[‘name‘]" value="张三"/></div>
  4. <div class="clear"></div>
  5. <div class="f_left">年龄:</div>
  6. <div class="f_left"><input name="user[‘age‘]" value="20"/></div>
  7. <div class="clear"></div>
  8. <div class="f_left">收入:</div>
  9. <div class="f_left"><input name="user[‘income‘]" value="100000"/></div>
  10. <div class="clear"></div>
  11. <div class="f_left">结婚:</div>
  12. <div class="f_left">
  13. <input type="radio" name="user[‘isMarried‘]" value="true" checked="checked"/>是
  14. <input type="radio" name="user[‘isMarried‘]" value="false"/>否</div>
  15. <div class="clear"></div>
  16. <div><input type="submit" value="提交表单"/></div>
  17. </form>

6.复合类型绑定

controller代码

[java] view plaincopy

  1. @RequestMapping  
  2.     public void test6(UserForm userForm)  
  3.     {  
  4.         System.out.println("复合类型绑定=========");  
  5.         System.out.println("名字:" + userForm.getUser().getName());  
  6.         System.out.println("年龄:" + userForm.getUser().getAge());  
  7.         System.out.println("收入:" + userForm.getUser().getIncome());  
  8.         System.out.println("已结婚:" + userForm.getUser().getIsMarried());  
  9.         System.out.println("========================");  
  10.     }  

 

UserForm代码

[java] view plaincopy

  1. public class UserForm {
  2. private Map<String, String> userMap = new LinkedHashMap<String, String>();
  3. private User user = new User();
  4. public Map<String, String> getUserMap() {
  5. return userMap;
  6. }
  7. public void setUserMap(Map<String, String> userMap) {
  8. this.userMap = userMap;
  9. }
  10. public User getUser() {
  11. return user;
  12. }
  13. public void setUser(User user) {
  14. this.user = user;
  15. }
  16. }

jsp代码

[xhtml] view plaincopy

  1. <form action="test6.do" method="post">
  2. <div class="f_left">姓名:</div>
  3. <div class="f_left"><input name="user.name" value="张三"/></div>
  4. <div class="clear"></div>
  5. <div class="f_left">年龄:</div>
  6. <div class="f_left"><input name="user.age" value="20"/></div>
  7. <div class="clear"></div>
  8. <div class="f_left">收入:</div>
  9. <div class="f_left"><input name="user.income" value="100000"/></div>
  10. <div class="clear"></div>
  11. <div class="f_left">结婚:</div>
  12. <div class="f_left">
  13. <input type="radio" name="user.isMarried" value="true" checked="checked"/>是
  14. <input type="radio" name="user.isMarried" value="false"/>否</div>
  15. <div class="clear"></div>
  16. <div><input type="submit" value="提交表单"/></div>
  17. </form>
时间: 2024-08-03 22:37:50

spring mvc 数据绑定总结的相关文章

spring mvc 数据绑定 400错误

情景:使用在方法中绑定数据的时候,打开链接,出现400错误. @RequestMapping(value = "editItemSubmit") public String editItemSubmit(int id, Items item) { itemService.updateItemFromId(id, item); return "redirect:queryItemlList"; } public class Items { private int id

Spring MVC 数据绑定(二)

Spring支持多种形式的类型绑定,包括: 1.基本数据类型.String和String[] 2.简单对象类型 3.List类型 4.Set类型 5.Map类型 6.复合数据类型 接下来一个一个的实现: 1.基本数据类型.String和String[]. 请求处理方法: public void registBean(String username,int age,double income,String[] interests,boolean marrid) 保证JSP页面上提交项和方法中对应参

Spring MVC 数据绑定流程

DataBinder ConversionService: 进行数据类型转换和数据格式化 Validators 进行数据合法性的校验, 把结果放入BindingResult 源码 原文地址:https://www.cnblogs.com/eason-d/p/9249001.html

Spring MVC HTTP请求数据绑定

package com.springmvc.controller; import com.springmvc.model.UserInfo; import org.springframework.core.io.ClassPathResource; import org.springframework.core.io.Resource; import org.springframework.stereotype.Controller; import org.springframework.uti

Spring MVC中数据绑定之日期类型

数据绑定应该算是Spring MVC的特点之一吧~简单易用且功能强大,极大地简化了我们编程人员对于用户输入数据的接收及转换. 早先版本的Spring中的数据绑定完全都是基于PropertyEditor的.而Spring3中引入了Converter,用来替代PropertyEditor完成类型转换. 那么我们也依照这个顺序,先来讲讲基于传统的PropertyEditor来实现日期类型的数据绑定. 在Spring MVC中,我们可以通过WebDataBinder来注册自定义的PropertyEdit

spring mvc使用@InitBinder 标签对表单数据绑定

在SpringMVC中,bean中定义了Date,double等类型,如果没有做任何处理的话,日期以及double都无法绑定. 解决的办法就是使用spring mvc提供的@InitBinder标签 在我的项目中是在BaseController中增加方法initBinder,并使用注解@InitBinder标注,那么spring mvc在绑定表单之前,都会先注册这些编辑器,当然你如果不嫌麻烦,你也可以单独的写在你的每一个controller中.剩下的控制器都继承该类.spring自己提供了大量的

视图框架:Spring MVC 4.0(1)

目录 一.表单标签库 1.1.简介 1.2.常用属性 1.3.form标签与input标签 1.4.checkbox标签 1.5.radiobutton标签 1.6.password标签 1.7.select标签 1.8.option标签 1.9.options标签 1.10.textarea.errors标签 1.11.hidden标签 1.12.radiobuttons 单选列表与checkboxs复选列表 二.视图解析器 2.1.ViewResolver视图解析器 2.2.链式视图解析器

Extjs5.0从入门到实战开发信息管理系统(Extjs基础、Extjs5新特性、Spring、Spring mvc、Mybatis)视频教程

Extjs5.0从入门到实战开发信息管理系统(Extjs基础.Extjs5新特性.Spring.Spring mvc.Mybatis)视频教程下载   联系QQ:1026270010 Extjs作为一款优秀的JS前端开发框架以其良好的架构.丰富的UI组件库.完善的文档和社区支持等诸多优点拥有广泛的市场应用空间,开发人员无需过多的关注HTML.CSS甚至各种常用JS算法,只需把精力放在业务逻辑上,利用各种组件的相互组合调用便可轻松而高效的开发出系统的前端页面. Extjs5在之前版本的基础上又推出

[转]Spring MVC 教程,快速入门,深入分析

.前言二.spring mvc 核心类与接口三.spring mvc 核心流程图 四.spring mvc DispatcherServlet说明 五.spring mvc 父子上下文的说明 六.springMVC-mvc.xml 配置文件片段讲解 七.spring mvc 如何访问到静态的文件,如jpg,js,css 八.spring mvc 请求如何映射到具体的Action中的方法 九. spring mvc 中的拦截器:十. spring mvc 如何使用拦截器 十一. spring mv