SpringMVC 官方文档:点此进入
有关 MVC 架构模式的内容见之前的笔记:点此进入
下图为 SpringMVC 的执行流程图,实线是 SpringMVC 框架提供的技术,不需要开发者实现,虚线需要实现。
组件:
步骤:
1 :用户发起请求到前端控制器 DispatcherServlet;
2 :前端控制器请求处理器映射器 HandlerMappering 去通过 xml 配置或者注解来查找处理器 Handle;
3-4 :找到处理器 Handle 以后 HandlerMappering 向前端控制器返回一个执行链 HandlerExecutionChain(包含了 Handle);
5 :前端控制器 DispatcherServlet 调用处理器适配器 HandlerAdapter 去执行处理器 Handler;
6 :处理器适配器去执行 Handler;
7 :Handler 执行完给处理器适配器 HandlerAdapter 返回 ModelAndView;
8 :处理器适配器 HandlerAdapter 向前端控制器返回 ModelAndView;
9 :前端控制器 DispatcherServlet 请求视图解析器 ViewResolver 去进行视图解析;
10 :视图解析器 ViewResolver 向前端控制器返回 View;
11 :前端控制器根据 View 对视图进行渲染,将 Model 中的模型数据填充到 View 视图中的 request 域,生成最终的 View(视图);
12 :前端控制器向用户响应结果。
备注:
SpringMVC 执行原理概述:拦截请求、解析 URL 找到处理器 Handle、执行 controller、解析数据和视图并展示。
SpringMVC 执行原理参考文档:
- 参考文档 1:点此进入
- 参考文档 2:点此进入
使用配置文件实现 SpringMVC 主要是为了理解 SpringMVC 的执行原理,步骤如下:
<dependency>
<groupId>javax.servletgroupId>
<artifactId>javax.servlet-apiartifactId>
<version>3.1.0version>
dependency>
<dependency>
<groupId>javax.servlet.jspgroupId>
<artifactId>jsp-apiartifactId>
<version>2.1version>
dependency>
<dependency>
<groupId>javax.servletgroupId>
<artifactId>jstlartifactId>
<version>1.2version>
dependency>
<dependency>
<groupId>taglibsgroupId>
<artifactId>standardartifactId>
<version>1.1.2version>
dependency>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-webmvcartifactId>
<version>5.3.18version>
dependency>
<dependency>
<groupId>junitgroupId>
<artifactId>junitartifactId>
<version>4.12version>
dependency>
Add Framework Support...
后勾选 Web Application(4.0)
将模块转变为一个 Web 模块。注意:因为没有使用模板创建 Web 项目,所以此时生成的 web 文件夹不在 main 文件下,这样生成的 out 文件夹中没有依赖,所以要打开项目结构,建立 lib 文件夹,导入依赖。web.xml
中配置 DispatcherServlet 前端控制器(整个 SpringMVC 的控制中心)
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<servlet>
<servlet-name>springmvcservlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
<init-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:spring-mvc.xmlparam-value>
init-param>
<load-on-startup>1load-on-startup>
servlet>
<servlet-mapping>
<servlet-name>springmvcservlet-name>
<url-pattern>/url-pattern>
servlet-mapping>
web-app>
spring-mvc.xml
配置文件:包括配置处理器映射器、处理器适配器、视图解析器
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd">
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
<bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
bean>
<bean id="/hello" class="com.Sun3285.controller.ControllerDemo01"/>
beans>
提示:可以将以上代码与第二部分 SpringMVC 的执行原理相对应起来看,可以加深理解。
在实际中,经常使用注解开发实现 SpringMVC,使用到的注解有:
注解 | 说明 |
---|---|
@Controller | 将编写的控制类注册为 bean,由 Spring 容器进行管理 |
@RequestMapping(“请求路径”) | 完成映射关系,根据请求路径找到对应的处理器(Controller 控制器) |
注解开发步骤如下:
web.xml
中配置 DispatcherServlet 前端控制器:
spring-mvc.xml
配置文件:
web.xml
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<servlet>
<servlet-name>springmvcservlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
<init-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:spring-mvc.xmlparam-value>
init-param>
<load-on-startup>1load-on-startup>
servlet>
<servlet-mapping>
<servlet-name>springmvcservlet-name>
<url-pattern>/url-pattern>
servlet-mapping>
web-app>
spring-mvc.xml
<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"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<context:component-scan base-package="com.Sun3285.controller"/>
<mvc:default-servlet-handler/>
<mvc:annotation-driven/>
<bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
bean>
beans>
在要跳转的页面中取出 message
对应的值
配置 Tomcat,测试
方法 | 说明 |
---|---|
addObject(String attributeName, Object attributeValue) | 以键值对的形式赋值 |
setViewName(String viewName) | 参数 viewName 通过视图解析器后组成 url 用于视图跳转 |
注意:这些方法由 ModelAndView 类型的对象执行。
方法 | 说明 |
---|---|
addAttribute(String attributeName, Object attributeValue) | 以键值对的形式赋值 |
注意:这个方法由 Model 类型的对象执行,相当于 ModelAndView 类的 addObject 方法。
将所有视图放在 WEB-INF 目录下,这样可以保证视图安全,因为这个目录下的文件,客户端不能直接访问;
在 web.xml
中配置 DispatcherServlet 前端控制器时,url-pattern
中要使用 /
:
/
:只匹配所有的请求,不会去匹配 jsp 页面;
/*
:匹配所有的请求,包括 jsp 页面。
在 spring-mvc.xml
配置文件中,通常我们只需要手动配置视图解析器,而处理器映射器和处理器适配器只需要开启注解驱动即可,省去了 xml 配置;
在控制类中:
使用配置文件实现 SpringMVC 主要是为了理解 SpringMVC 的执行原理,而使用注解开发实现 SpringMVC 才是实际中经常用到的。