[Spring MVC] -简单表单提交实例

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=2, max=50, 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=18, message="最小18岁")
  @Max(value=100, 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.get(0);
    user.setId(1);
    user.setName("Robin");
    user.setCreateTime(new Date());
    user.setGirl(true);
    user.setCbx(new String[] {"1", "2", "3"});
    user.setAge(18);
    user.setEmail("abcd@abc.com");

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

    Customer customer2 = new Customer();
    customer2.setId(1);
    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() + 1);
    user.getCustomers().get(0).setId(1);
    user.getCustomers().get(0).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="checkbox" name="cbx" id="cbx1" value="1" /><label for="cbx1">1</label>
    <input type="checkbox" name="cbx" id="cbx2" value="2" /><label for="cbx2">2</label>
    <input type="checkbox" name="cbx" id="cbx3" value="3" /><label for="cbx3">3</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、测试结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 基于Spring MVC 简介及入门小例子(推荐)

    一.什么是 Spring MVC Spring MVC 属于 SpringFrameWork 的后续产品,已经融合在 Spring Web Flow 里面,是一个强大灵活的 Web 框架.Spring MVC 提供了一个 DispatcherServlet 作为前端控制器来分配请求.通过策略接口,Spring 框架是高度可配置的.Spring MVC 还包含多种视图技术,如 Java Server Pages(JSP).Velocity.Tiles.iText 和 POI 等.Spring MV

  • 详解SpringMVC 基础教程 简单入门实例

    一个简单的入门实例教程 该实例的源码和实例中的jar 源码:http://xiazai.jb51.net/201612/yuanma/SpringMVC_jb51.zip 所需要的jar: http://xiazai.jb51.net/201612/yuanma/SpringMVCjar_jb51.zip 另外一篇关于SpringMVC 文件上传,多文件上传:http://www.jb51.net/article/100491.htm 简单注解配置的实例: 一.创建项目: 1.建立新的动态web

  • SpringMvc入门指南(必看)

    Spring Web MVC是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web框架,即使用了MVC架构模式的思想,将web层进行职责解耦,基于请求驱动指的就是使用请求-响应模型,框架的目的就是帮助我们简化开发,Spring Web MVC也是要简化我们日常Web开发的. Spring Web MVC也是服务到工作者模式的实现,但进行可优化.前端控制器是DispatcherServlet:应用控制器其实拆为处理器映射器(Handler Mapping)进行处理器管理和视图

  • 史上最全最强SpringMVC详细示例实战教程(图文)

    一.SpringMVC基础入门,创建一个HelloWorld程序 1.首先,导入SpringMVC需要的jar包. 2.添加Web.xml配置文件中关于SpringMVC的配置 <!--configure the setting of springmvcDispatcherServlet and configure the mapping--> <servlet> <servlet-name>springmvc</servlet-name> <serv

  • [Spring MVC] -简单表单提交实例

    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

  • Spring MVC接受表单自动封装特性实例解析

    这篇文章主要介绍了Spring MVC接受表单自动封装特性实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Spring MVC中的Controller可以以实体类接受来自客户端的form表单,表单的字段自动构成实体类对象 客户端的表单 <form action="http://localhost:8080/test/user" method="POST"> <!-- 每个字段名对应实体类

  • php表单提交实例讲解

    本文为大家分享了一个特别简单的php表单提交实例,具体的实现步骤如下: 实例代码如下: <form action="someform.php" method="post"> <table width="541" border="0"> <tr> <td width="26%">姓名:</td> <td width="74%"

  • Python 自动化表单提交实例代码

    今天以一个表单的自动提交,来进一步学习selenium的用法 练习目标 0)运用selenium启动firefox并载入指定页面(这部分可查看本人文章 http://www.cnblogs.com/liu2008hz/p/6958126.html) 1)页面元素查找(多种查找方式:find_element_*) 2)内容填充(send_keys) 3)iframe与父页面切换(switch_to_frame是切换到iframe,switch_to_default_content是切换到主页面)

  • AngularJS表单提交实例详解

    本文实例讲述了AngularJS表单提交.分享给大家供大家参考,具体如下: AngularJS中的数据绑定 AngularJS创建实时模板来代替视图,而不是将数据合并进模板之后更新DOM.任何一个独立视图组件中的值都是动态替换的. ng-app属性声明所有被其包含的内容都属于这个AngularJS应用,这也是我们可以在Web应用中嵌套AngularJS应用的原因.只有被具有ng-app属性的DOM元素包含的元素才会受AngularJS影响. 当AngularJS认为某个值可能发生变化时,它会运行

  • mvc form表单提交的几种形式整理总结

    mvc中form表单提交的几种形式 第一种方式:submit 按钮 提交 <form action="MyDemand" method="post"> <span>关键字:</span> <input name="keywords" type="text" value="@keywords" /> <input type="submit&quo

  • jquery插件EasyUI中form表单提交实例分享

    之前用AJax给Controller传递参数,然后再调用服务端的方法对数据库进行更改,今天碰到一个新的方法,就是表单的提交,这样可以省去AJax传参. 当表单提交后,我们可以获取表单上控件中的值,然后再调用服务端的方法对数据库进行更改.下面的一张截图是具体的业务需求. 一.要实现的功能:从上面这个表单中,获取控件中的值,然后传递给后台.下面是表单代码. 二.表单代码 <div id="Editwin" class="easyui-window" title=&

  • 微信小程序 PHP后端form表单提交实例详解

    微信小程序 PHP后端form表单 1.小程序相对于之前的WEB+PHP建站来说,个人理解为只是将web放到了微信端,用小程序固定的格式前前端进行布局.事件触发和数据的输送和读取,服务器端可以用任何后端语言写,但是所有的数据都要以JSON的形式返回给小程序. 2.昨天写了登录注册.忘记密码功能,他们实质上都是一个表单提交操作.因此就拿注册功能来写这个例子. 3.目录图 js文件是逻辑控制,主要是它发送请求和接收数据, json 用于此页面局部 配置并且覆盖全局app.json配置, wxss用于

  • JQuery打造PHP的AJAX表单提交实例

    如果你对JQuery的基本语法还不是很熟悉,请搜索本站的教程资源.如果你对PHPMailer用法不熟悉,请查看本站的另一篇文章<使用PHPMailer类库发送电子邮件>. 第一步,创建一个表单HTML页面 这里,我们只展示主要的表单部分HTML结构代码: 复制代码 代码如下: <div id="contact_form"> <form name="contact" method="post" action="

  • layui 图片上传+表单提交+ Spring MVC的实例

    Layui 的上传是最常用的, 不可或缺, 记录一下代码, 以后复制都能用!! 1.前端HTML: <div class="layui-form-item"> <label class="layui-form-label">修改头像</label> <div class="layui-input-inline uploadHeadImage"> <div class="layui-u

随机推荐