Spring MVC表单处理

转自http://www.yiibai.com/spring_mvc/springmvc_form_handling.html#

以下示例演示如何编写一个简单的基于Web的应用程序,它使用Spring Web MVC框架使用HTML表单。 首先使用Eclipse IDE,并按照以下步骤使用Spring Web Framework开发基于动态表单的Web应用程序:

  1. 基于上一小节中的Spring MVC - Hello World实例章节所创建的 HelloWeb来创建一个新的工程为:FormHandling,并创建一个包名称为 com.yiibai.springmvc
  2. com.yiibai.springmvc包下创建两个Java类StudentStudentController
  3. jsp子文件夹下创建两个视图文件student.jspresult.jsp
  4. 最后一步是创建所有源和配置文件的内容并运行应用程序,如下所述。

完整的项目文件结构如下所示 -

Student.java文件中的代码内容 -

package com.yiibai.springmvc;

public class Student {
   private Integer age;
   private String name;
   private Integer id;

   public void setAge(Integer age) {
      this.age = age;
   }
   public Integer getAge() {
      return age;
   }

   public void setName(String name) {
      this.name = name;
   }
   public String getName() {
      return name;
   }

   public void setId(Integer id) {
      this.id = id;
   }
   public Integer getId() {
      return id;
   }
}

  
  
Java

StudentController.java 文件中的代码内容 -

package com.yiibai.springmvc;

import org.springframework.stereotype.Controller;
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 org.springframework.ui.ModelMap;

@Controller
public class StudentController {

   @RequestMapping(value = "/student", method = RequestMethod.GET)
   public ModelAndView student() {
      return new ModelAndView("student", "command", new Student());
   }

   @RequestMapping(value = "/addStudent", method = RequestMethod.POST)
   public String addStudent(@ModelAttribute("SpringWeb")Student student, 
   ModelMap model) {
      model.addAttribute("name", student.getName());
      model.addAttribute("age", student.getAge());
      model.addAttribute("id", student.getId());

      return "result";
   }
}

  
  
Java

这里的第一个服务方法student(),我们已经在ModelAndView对象中传递了一个名为“command”的空对象,因为如果在JSP中使用<form:form>标签,spring框架需要一个名为“command”的对象文件。 所以当调用student()方法时,它返回student.jsp视图。

第二个服务方法addStudent()将在 URLHelloWeb/addStudent上的POST方法提交时调用。将根据提交的信息准备模型对象。最后,将从服务方法返回“result”视图,这将最终渲染result.jsp视图。

student.jsp文件的内容如下所示 -

<%@ page contentType="text/html; charset=UTF-8" %>
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<html>
<head>
    <title>Spring MVC表单处理</title>
</head>
<body>

<h2>Student Information</h2>
<form:form method="POST" action="/FormHandling/addStudent">
   <table>
    <tr>
        <td><form:label path="name">名字:</form:label></td>
        <td><form:input path="name" /></td>
    </tr>
    <tr>
        <td><form:label path="age">年龄:</form:label></td>
        <td><form:input path="age" /></td>
    </tr>
    <tr>
        <td><form:label path="id">编号:</form:label></td>
        <td><form:input path="id" /></td>
    </tr>
    <tr>
        <td colspan="2">
            <input type="submit" value="提交表单"/>
        </td>
    </tr>
</table>  
</form:form>
</body>
</html>

  
  
HTML

result.jsp文件的内容如下 -

<%@ page contentType="text/html; charset=UTF-8" %>
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<html>
<head>
    <title>Spring MVC表单处理</title>
</head>
<body>

<h2>提交的学生信息如下 - </h2>
   <table>
    <tr>
        <td>名称:</td>
        <td>${name}</td>
    </tr>
    <tr>
        <td>年龄:</td>
        <td>${age}</td>
    </tr>
    <tr>
        <td>编号:</td>
        <td>${id}</td>
    </tr>
</table>  
</body>
</html>

  
  
HTML

完成创建源和配置文件后,导出应用程序。 右键单击应用程序,并使用导出> WAR文件选项,并将 FormHandling.war 文件保存在Tomcat的webapps文件夹中。或者直接右键选择“Run As -> Run On Server”。

启动Tomcat服务器,并确保您能够使用标准浏览器从webapps文件夹访问其他网页。现在尝试URL => http://localhost:8080/FormHandling/student ,如果Spring Web应用程序没有问题,那么应该看到以下结果:

提交所需信息后,点击提交按钮提交表单。 如果Spring Web应用程序没有问题,应该看到以下结果:

关于form标签学习:

form标签用于渲染HTML表单。 form标签必须利用
渲染表单输入字段的其他任意标签。
form标签的属性如
19.2所示。
19.2中的所有标签都是可选的。 这个表中没有包
HTML属性, 如methodaction
19.2 form标签的属性

属性 描述
acceptCharset 定义服务器接受的字符编码列表
commandName 显示表单对象之模型属性的名称。 默认为command
cssClass 定义要应用到被渲染form元素的CSS
cssStyle 定义要应用到被渲染form元素的CSS样式
htmlEscape 接受true或者false, 表示被渲染的值是否应该进行HTML转义
modelAttribute 显示form backing object的模型属性名称。 默认为command

commandName 属性或许是其中最重要的属性, 因
为它定义了模型属性的名称, 其中包含了一个
backing
object
, 其属性将用于填充所生成的表单。 如果该属性
存在, 则必须在返回包含该表单的视图的请求处理方法
中添加相应的模型属性。 例如, 在本章配套的
app19a
用程序中, 下列
form 标签是在 BookAddForm.jsp 中定义
的:
<form:form commandName="book" action="book_save" method="post">
...
</form:form>
BookController 类中的 inputBook 方法, 是返回
BookAddForm.jsp 的请求处理方法。 下面就是 inputBook
方法。
@RequestMapping(value = "/book_input")
public String inputBook(Model model) {
...
model.addAttribute("book", new Book());
return "BookAddForm";
}
此处用 book 属性创建了一个 Book 对象, 并添加到
Model 。 如果没有 Model 属性, BookAddForm.jsp 页面就
会抛出异常, 因为
form 标签无法找到在其
commandName 属性中指定的 from backing object
此外, 一般来说仍然需要使用
action method
性。 这两个属性都是
HTML 属性, 因此不在表 19.2
列。







  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值