Spring MVC
一、概述
1.1什么是SpringMVC
复习MVC
MVC提倡:每层编写自己的东西, 不写任何与该层无关的代码
分层的目的:为了解耦,分工明确,方便后期代码维护。
Spring MVC是Spring Framework的一部分,是基于Java实现MVC的轻量级Web框架
1.2Spring MVC的特点:
- 轻量级,简单易学
- 高效,基于请求响应的MVC框架
- 与Spring兼容性好, 无缝结合
- 约定优于配置
- 功能强大: RESTful、 数据验证、格式化、本地化、主题等
- 简洁灵活
1.3核心组件:
- DispatcherServlet: 前置控制器,负责调度其他组件的执行,可以降低不同组件之间的耦合性,是整个Sprring MVC 的核心模块。
- Handler: 处理器,完成具体的业务逻辑,相当于Servlet。
- HandlerMapping: DispatcherServlet是通过HandlerMapping将请求映射到不同的Handler。
- HandlerInterceptor: 处理器拦截器,是一个接口,如果我们需要进行一些拦截处理,可以通过实现该接口完成。
- HandlerExecutionChain: 处理器执行链,包括两部分内容: Handler 和HandlerInterceptor (系统会有一个默认的HandlerInterceptor,如果需要额外拦截处理,可以添加拦截器进行设置)。
- HandlerAdapter: 处理器适配器,Handler 执行业务方法之前,需要进行一系列的操作包括表单的数据验证、数据类型的转换、将表单数据封装到POJO等,这一些列操作都是由
HandlerAdapter完成,DispatcherServlet通过HandlerAdapter执行不同的Handler。 - ModelAndView: 封装了模型数据和视图信息,作为Handler的处理结果,返回给DispatcherServlet。
- ViewResolver: 视图解析器,DispatcherServlet 通过它将逻辑视图解析为物理视图,最终将渲染的结果响应给客户端。
1.4工作流程
- 客户端请求被DispatcherServlet接收。
- 根据HandlerMapping映射到Handler.
- 生成Handler和HandlerInterceptor。
- Handler 和HandlerInterceptor以HandlerExecutionChain的形式一并返回给DispatcherServlet。
- DispatcherServlet 通过HandlerAdpater调用Handler的方法完成业务逻辑处理。
- 返回一个ModelAndView对象给DispatcherServlet。
- DispatcherServlet 将获取的ModelAndView对象传给ViewResolver视图解析器,将逻辑视图解析成物理视图。
- ViewResolver返回一个View给DispatcherServlet。
- DispatcherServlet根据View进行视图渲染(将模型数据填充到视图中)
- DispatcherServlet将渲染之后的视图响应给客户端。
二.入门案列
2.1 流程梳理
1、DispatcherServlet 接收到URL请求index,结合@RequestMapping"/index")注解将该请求交给index业务方法进行处理。
2、执行index业务方法,控制台打印日志,并且返回"index"字符串(逻辑视图)。
3、结合springmvc.xml中的视图解析器配置,找到目标资源: /index.jsp, 即根目录下的index.jsp文件,将该JSP资源返回给客户端完成响应。
Spring MVC环境搭建成功。
1.导入相关依赖
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.2</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
</dependencies>
2.在web.xml中配置前端控制器
<web-app>
<display-name>Archetype Created Web Application</display-name>
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<!--DispatcherServlet 对象的创建是在使⽤时创建,如果需要在运⾏时创建,则需要通过load-on-startup 进⾏设置,数值越⼩,加载的优先级越⾼-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<!--
/ 拦截 所有请求
/* 拦截所有请求,但是视图层的请求是不可以访问
http://localhost:8080/springmvc/index.jsp
http://localhost:8080/springmvc/hello
-->
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
3.在 resources中创建SpringMVC配置文件:spring-mvc.xml
<!--注解扫描-->
<context:component-scan base-package="com.wdzl..controller"></context:component-scan>
<!--视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="WEB-INF/pages/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
4.编写请求处理器,并表示为控制器,同时为类中的方法提供请求路径
@Controller
public class HelloController {
@RequestMapping("/hello")
public String hello() {
return "/success.jsp";
}
}
2.2 Spring MVC 常用注解
@RequestMapping常用参数
- value :指定URL请求的实际地址,是@RequestMapping的默认值(也可以用path)
@RequestMapping(value = "/d1")
public String index(){
System.out.println("接收到了");
return "index";
}
- method : 指定请求的method 类型,包括GET、POST、PUT、DELETE等。
//只能用post方法请求
@RequestMapping(value = "/d1",method = RequestMethod.POST)
public String index(){
System.out.println("接收到了");
return "index";
}
- params:指定request请求中必须包含的参数值,若不包含,无法调用该方法。
- params={“userName”},表示请求参数必须是有userName
- params={“age!=10”},表示请求参数中age不能为10。
@RequestMapping(value = "/d1",params={
"id=1","name=tom"})
public String index(int id,String name){
System.out.println(id+":"+name);
System.out.println("接收到了");
return "index";
}
2.3 Spring MVC组件扫描
SpringMVC注解扫描的两种写法
方式一:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!--注解扫描-->
<context:component-scan base-package="com.wdzl..controller"></context:component-scan>
</beans>
方式二:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!--注解扫描-->
<context:component-scan base-package="com.wdzl">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
</beans>
三、 SpringMVC 的数据响应
3.1 页面跳转 - 直接返回字符串
直接返回字符串:此种方式会将返回的字符串与视图解析器的前后缀进行拼接,然后跳转。
1. 直接返回字符串
2. 返回带前缀的字符串
Spring MVC默认以转发的形式响应JSP,可以手动进行修改。
转发
@RequestMapping("/d1/t1")
public String test(){
return "forward:/index.jsp";
}
相当于
@RequestMapping("/d1/t2")
public String test2(){
return "index";
}
重定向
@RequestMapping("/d1/t3")
public String