【图书介绍】《Spring+Spring MVC+MyBatis从零开始学(视频教学版)(第3版)》_spring+springmvc+mybatis从零开始 代码、课件、教学视频与相关软件包下载-CSDN博客
《Spring+Spring MVC+MyBatis从零开始学(视频教学版)(第3版)》(杨章伟,刘祥淼)【摘要 书评 试读】- 京东图书
编程与应用开发_夏天又到了的博客-CSDN博客
【图书介绍】案例可借鉴的Spring应用开发书-CSDN博客
简单数据绑定包括绑定默认数据类型、绑定简单数据类型、绑定POJO类型、绑定包装POJO等。
当前端请求的参数比较简单时,可以在后台方法的形参中直接使用Spring MVC提供的默认参数类型进行数据绑定。
常用的默认参数类型如下。
- HttpServletRequest:通过request对象获取请求信息。
- HttpServletResponse:通过 response对象处理响应信息。
- HttpSession:通过session对象得到session中存储的对象。
- Model/ModelMap:Model是一个接口,ModelMap是一个接口实现,作用是将Model数据填充到request域。
【示例12-1】以HttpServletRequest类型的使用为例进行演示说明,具体步骤如下:
在IntelliJ IDEA中创建一个名为chapter12的Web项目,然后将Spring MVC相关JAR包添加到项目的lib目录下,并发布到类路径中。添加JAR包后的目录如图12.1所示。
图12.1 Spring MVC相关JAR包
在web.xml中配置Spring MVC的前端控制器等信息,如文件12.1所示。
文件12.1 web.xml
01 <?xml version="1.0" encoding="UTF-8"?>
02 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
03 xmlns="http://xmlns.jcp.org/xml/ns/javaee"
04 xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
05 http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
06 id="WebApp_ID" version="4.0">
07 <servlet>
08 <!-- 配置前端过滤器 -->
09 <servlet-name>springmvc</servlet-name>
10 <servlet-class>org.srpingframework.web.servlet.DispatcherServlet
</servlet-class>
11 <!-- 初始化时加载配置文件 -->
12 <init-param>
13 <param-name>contextConfigLocation</param-name>
14 <param-value>classpath:springmvc-config.xml</param-value>
15 </init-param>
16 <!-- 表示容器在启动时立即加载Servlet -->
17 <load-on-startup>1</load-on-startup>
18 </servlet>
19 <servlet-mapping>
20 <servlet-name>springmvc</servlet-name>
21 <url-pattern>/</url-pattern>
22 </servlet-mapping>
23 </web-app>
在src目录下创建Spring MVC的核心配置文件springmvc-config.xml,在该文件中配置组件扫描器和视图解析器(参见注释),如文件12.2所示。
文件12.2 springmvc-config.xml
01 <?xml version="1.0" encoding="UTF-8"?>
02 <beans xmlns="http://www.springframework.org/schema/beans"
03 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
04 xmlns:context="http://www.springframework.org/schema/context"
05 xsi:schemaLocation="http://www.springframework.org/schema/beans
06 http://www.springframework.org/schema/beans/spring-beans.xsd
07 http://www.springframework.org/schema/context
08 http://www.springframework.org/schema/context/spring-context
.xsd">
09 <!--指定需要扫描的包 -->
10 <context:component-scan base-package="com.ssm.controller" />
11 <!-- 定义视图解析器 -->
12 <bean id="viewResolver"
13 class="org.springframework.web.servlet.view.
InternalResourceViewResolver">
14 <!-- 设置前缀 -->
15 <property name="prefix" value="/WEB-INF/jsp/" />
16 <!-- 设置后缀 -->
17 <property name="suffix" value=".jsp" />
18 </bean>
19 </beans>
在src目录下创建一个com.ssm.controller包,在该包下创建一个用于用户操作的控制器类UserController,编写后的代码如文件12.3所示。
文件12.3 UserController.java
01 package com.ssm.controller;
02 import javax.servlet.http.HttpServletRequest;
03 import org.springframework.stereotype.Controller;
04 import org.springframework.web.bind.annotation.RequestMapping;
05 //@Controller注解
06 @Controller
07 public class UserController {
08 //@RequestMapping注解在方法上
09 @RequestMapping(value="/selectUser")
10 public String selectUser(HttpServletRequest request) {
11 //获取请求地址中的参数id的值
12 String id=request.getParameter("id");
13 System.out.println("id="+id);
14 return "success";
15 }
16 }
在文件12.3中,使用注解方式定义了一个控制器类,同时定义了方法的访问路径。在方法参数中使用了HttpServletRequest类型,并通过该对象的getParameter()方法获取了指定的参数。为了方便查看结果,将获取的参数进行输出打印,最后返回一个名为success的视图,Spring MVC会通过视图解析器在WEB-INF/jsp路径下寻找success.jsp文件。
注意:后台在编写控制器类时,通常会根据需要操作的业务对控制器类进行规范命名。例如,如果要编写一个对用户操作的控制器类,可以将控制器类命名为UserController,然后在该控制器类中就可以编写任何有关用户操作的方法。
在WEB-INF目录下创建一个名为jsp的文件夹,然后在该文件夹中创建页面文件success.jsp,该页面只作为正确执行操作后的响应页面,没有其他业务逻辑,如文件12.4所示。
文件12.4 success.jsp
01 <%@ page language="java" contentType="text/html; charset=UTF-8"
02 pageEncoding="UTF-8"%>
03 <!DOCTYPE HTML>
04 <html>
05 <head>
06 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
07 <title>入门程序</title>
08 </head>
09 <body>
10 ok!,执行成功
11 </body>
12 </html>
将chapter12项目发布到Tomcat服务器中并启动,在浏览器中访问地址http://localhost:8080/chapter12_war_exploded/selectUser?id=1,其显示效果如图12.2所示。
图12.2 执行结果(success.jsp页面)
此时的控制台输出信息如图12.3所示。从结果中可以看出,后台方法已从请求地址中正确地获取到了id的参数信息,这说明使用默认的HttpServletRequest参数类型已经完成了数据绑定。
图12.3 运行结果