Spring MVC自带的表单标签比较简单,很多时候需要借助EL和JSTL来完成。

下面是一个比较简单的表单提交页面功能:

1、User model

package com.my.controller.bean;

import java.util.Date;
import java.util.List;

import javax.validation.constraints.Future;
import javax.validation.constraints.Max;
import javax.validation.constraints.Min;
import javax.validation.constraints.NotNull;

import org.hibernate.validator.constraints.Email;
import org.hibernate.validator.constraints.Length;
import org.hibernate.validator.constraints.NotEmpty;

public class User {

    private long id;

    @Length(min=, max=, message="User name length range = 2-50")
    private String name;

    @Future(message="时间不能小于今天")
    private Date createTime;

    @NotEmpty(message="Customer不能为空")
    private List<Customer> customers;

    @NotNull(message="Girl不能为空")
    private boolean girl;

    private String[] cbx;

    @NotNull(message="Age can NOT be Null")
    @Min(value=, message="最小18岁")
    @Max(value=, message="最大100岁")
    private int age;

    @Email(message="Email格式不正确")
    private String email;

    public long getId() {
        return id;
    }
    public void setId(long id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Date getCreateTime() {
        return createTime;
    }
    public void setCreateTime(Date createTime) {
        this.createTime = createTime;
    }
    public List<Customer> getCustomers() {
        return customers;
    }
    public void setCustomers(List<Customer> customers) {
        this.customers = customers;
    }
    public boolean isGirl() {
        return girl;
    }
    public void setGirl(boolean girl) {
        this.girl = girl;
    }
    public String[] getCbx() {
        return cbx;
    }
    public void setCbx(String[] cbx) {
        this.cbx = cbx;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }

}

2、Controller

package com.my.controller;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import javax.validation.Valid;

import org.springframework.stereotype.Controller;
import org.springframework.validation.BindingResult;
import org.springframework.validation.FieldError;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;

import com.my.controller.bean.Customer;
import com.my.controller.bean.User;

@Controller
@RequestMapping(value="/post")
public class TestPostController {

    private static List<User> users = new ArrayList<User>();
    {
        //-----------------------------------------------
        // 设置Entity
        // -----------------------------------------------
        users.add(new User());
        User user = users.);
        user.setId();
        user.setName("Robin");
        user.setCreateTime(new Date());
        user.setGirl(true);
        user.setCbx("});
        user.setAge();
        user.setEmail("abcd@abc.com");

        user.setCustomers(new ArrayList<Customer>());
        Customer customer1 = new Customer();
        customer1.setId();
        customer1.setCompany("Company - 1");
        customer1.setCreateTime(new Date());
        customer1.setUser(user);
        user.getCustomers().add(customer1);

        Customer customer2 = new Customer();
        customer2.setId();
        customer2.setCompany("Company - 2");
        customer2.setCreateTime(new Date());
        customer2.setUser(user);
        user.getCustomers().add(customer2);
    }

    @RequestMapping
    public ModelAndView index() {
        ModelAndView view = new ModelAndView("TestPost/index");
        view.addObject("users", users);
        return view;
    }

    @RequestMapping(value="/addUser", method=RequestMethod.POST)
    public ModelAndView addUser(@ModelAttribute @Valid User user, BindingResult result) {
        ModelAndView view = new ModelAndView("redirect:/post");

        if(result.hasErrors()) {
            List<FieldError> errors = result.getFieldErrors();
            for(FieldError err : errors) {
                System.out.println("ObjectName:" + err.getObjectName() + "\tFieldName:" + err.getField()
                        + "\tFieldValue:" + err.getRejectedValue() + "\tMessage:" + err.getDefaultMessage());
            }
            view.addObject("users", users);
            return view;
        }

        user.setId(users.size() + );
        user.getCustomers().).setId();
        user.getCustomers().).setUser(user);
        users.add(user);
        view.addObject("users", users);
        return view;
    }

}

3、View

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page import="com.my.controller.bean.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%@ taglib prefix="st" uri="http://www.springframework.org/tags" %>
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="sf" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Index</title>
</head>
<body>
    <fmt:setLocale value="zh_cn" />
    <form action="<st:url value="/post/addUser"></st:url>" method="post">
        <c:forEach items="${users}" var="user">
            User:${user.name}<br/>
            Create time:<fmt:formatDate value="${user.createTime}"/><br/>
            Is girl:
            <c:choose>
                <c:when test="${user.girl}">Yes</c:when>
                <c:when test="${!user.girl}">No</c:when>
                <c:otherwise>N/A</c:otherwise>
            </c:choose>
            <br/>
            Checkboxs:
            <c:forEach items="${user.cbx}" var="item">
                ${item},
            </c:forEach>
            <br/>
            Age:${user.age}<br/>
            E-mail:${user.email}<br/>
            <hr/>

            <table style="width:100%;border:1px solid #ccc;">
                <thead>
                    <tr style="text-align:left; background-color:#eee;">
                        <th>Company name</th>
                        <th>User</th>
                        <th>Create time</th>
                    </tr>
                </thead>
                <tbody>
                    <c:forEach items="${user.customers}" var="item">
                    <tr>
                        <td>${item.company}</td>
                        <td>${item.user.name}</td>
                        <td><fmt:formatDate value="${item.createTime}" pattern="yyyy-MM-dd"/></td>
                    </tr>
                    </c:forEach>
                </tbody>
            </table>
            <hr/>
        </c:forEach>

        User name:
        <input type="text" name="name" id="name" /><br/>
        Is girl:
        <input type="radio" name="girl" id="isGirl" value="true" checked="checked" /><label for="isGirl">Yes</label>
        <input type="radio" name="girl" id="noGirl" value="false" /><label for="noGirl">No</label><br/>
        Checkboxs:
        <input type=</label>
        <input type=</label>
        <input type=</label>
        <br/>
        Age:<input type="text" name="age" id="age" /><br/>
        E-mail:<input type="text" name="email" id="email" /><br/>
        Create time:
        <input type="text" name="createTime" id="createTime" /><br/>
        Company:
        <input type="text" name="customers[0].company" id="customers[0].company" /><br/>
        <input type="submit" value="add" />
        <sf:errors path="*"></sf:errors>
    </form>
    <hr/>
</body>
</html>

4、测试结果

springmvc 表单提交的更多相关文章

  1. SpringMVC中使用bean来接收form表单提交的参数时的注意点

    这是前辈们对于SpringMVC接收表单数据记录下来的总结经验: SpringMVC接收页面表单参数 springmvc请求参数获取的几种方法 下面是我自己在使用时发现的,前辈们没有记录的细节和注意点 ...

  2. 第6章—渲染web视图—SpringMVC+Thymeleaf 处理表单提交

    SpringMVC+Thymeleaf 处理表单提交 thymleaf处理表单提交的方式和jsp有些类似,也有点不同之处,这里操作一个小Demo,并说明: 1.demo的结构图如下所示: pom.xm ...

  3. SpringMVC(十四):SpringMVC 与表单提交(post/put/delete的用法);form属性设置encrypt='mutilpart/form-data'时,如何正确配置web.xml才能以put方式提交表单

    SpringMVC 与表单提交(post/put/delete的用法) 为了迎合Restful风格,提供的接口可能会包含:put.delete提交方式.在springmvc中实现表单以put.dele ...

  4. springmvc下js控制表单提交(表单提交前检验,提交后获取json返回值)

    这个问题我搞了四天,终于搞懂.因为对js很不熟悉.郁闷的是后台代码出错总可以设置断点调试,前端js代码出错只能通过浏览器提供一些运行数据来分析,很不习惯. 首先说下逻辑:这是一个注册功能,我希望,注册 ...

  5. SpringMVC 表单标签 & 处理静态资源

    使用 Spring 的表单标签 通过 SpringMVC 的表单标签可以实现将模型数据中的属性和 HTML 表单元素相绑定,以实现表单数据更便捷编辑和表单值的回显. form 标签 一般情况下,通过 ...

  6. 浏览器下载/导出文件 及jQuery表单提交

    1 比如以下按钮, 用于导出文件,如EXCEL文件. <li> <button class="whiteBg btn2" onclick="doExp( ...

  7. (转载)SPRINGMVC表单标签简介

    SpringMVC表单标签简介 在使用SpringMVC的时候我们可以使用Spring封装的一系列表单标签,这些标签都可以访问到ModelMap中的内容.下面将对这些标签一一介绍. 在正式介绍Spri ...

  8. SpringMVC表单标签简介

    在使用SpringMVC的时候我们可以使用Spring封装的一系列表单标签,这些标签都可以访问到ModelMap中的内容.下面将对这些标签一一介绍. 在正式介绍SpringMVC的表单标签之前,我们需 ...

  9. 【转载】springMVC表单校验+全注解

    在这篇文章中,我们将学习如何使用Spring表单标签, 表单验证使用 JSR303 的验证注解,hibernate-validators,提供了使用MessageSource和访问静态资源(如CSS, ...

随机推荐

  1. Java程序设计之扑克牌

    这段代码的主要实现功能扑克牌的洗牌和发牌功能,一副牌,红桃,黑桃,梅花,方片,A~K,不含大小王. 构造一个class. 首先是声明花色: private String[] sign={"方 ...

  2. jQuery与Struts2综合应用[stream/json]

    一.使用stream类型的Result实现Ajax 具体步骤: ① 定义InputStream类型的成员变量及getter和setter ②具体业务方法中将要发送到客户端的json字符串赋值给成员变量 ...

  3. ASP.NET SessionState 解惑

    踩坑 近日在对一个ASP.NET WEBFORM项目进行调优过程中,偶然发现页面POSTBACK事件是串行处理的,甚至不同页面的请求都是串行处理的(一个页面加载完毕后,才开始加载第二个页面).但是网站 ...

  4. 基于Emgu CV的人脸检测代码

    这个提供的代码例子是Emgu CV提供的源码里面自带的例子,很好用,基本不需要改,代码做的是人脸检测不是人脸识别,这个要分清楚.再就是新版本的Emgu CV可能会遇到系统32位和64位处理方式有区别的 ...

  5. 解决:sudo: 无法解析主机:dinphy-500-310cn: 连接超时

    出现这种问题是hosts文件没有配置好所导致的,linux无法解析到您的主机地址,解决方案如下: sudo vim /etc/hosts 其中vim是你的文本编辑器的命令,你如果电脑中没有vim,用g ...

  6. 使用canvas绘制一片星空

    效果图 五角星计算方式 代码 <body style="margin:0px;padding:0px;width:100%;height:100%;overflow:hidden;&q ...

  7. Javascript知识点记录(二)

    Javascript入门易,精通难,基本上是共识的一个观点.在这个篇幅里,主要对一些难点进行记录. 鸭子类型 Javascript属于动态类型语言的一种.对变量类型的宽容,给了很大的灵活性.由于无需类 ...

  8. Beta阶段第三次Scrum Meeting

    情况简述 Beta阶段第三次Scrum Meeting 敏捷开发起始时间 2016/12/12 22:00 敏捷开发终止时间 2016/12/13 22:00 会议基本内容摘要 讨论决定了APP的名称 ...

  9. jQuery5~7章笔记 和 1~3章的复习笔记

    JQery-05 对表单和表格的操作及其的应用 JQery-06 jQuery和ajax的应用 JQery-07 jQuery插件的使用和写法 JQery-01-03 复习 之前手写的笔记.实在懒得再 ...

  10. 自学 Java 怎么入门

    自学 Java 怎么入门? 595赞同反对,不会显示你的姓名     给你推荐一个写得非常用心的Java基础教程:java-basic | 天码营 这个教程将Java的入门基础知识贯穿在一个实例中,逐 ...