SpringMVC基础
一、SpringMVC概述
1、什么是SpringMVC
实现 MVC 设计模式的请求驱动型的轻量级 Web 框架,支持RESTful风格,支持全注解零配置。
2、请求响应流程
- 用户发送请求到前端控制器
- 前端控制器调用映射器,映射器根据请求路径查找与@RequestMapping匹配的处理器
- 映射器返回处理器给前端控制器
- 前端控制器请求适配器去执行处理器
- 处理器执行
- 处理器执行完成返回ModelAndView给适配器
- 适配器再返回给前端控制器
- 前端控制器把ModelAndView传给视图解析器
- 视图解析器解析后返回视图对象给前端控制器
- 前端控制器对视图对象进行渲染
- 前端控制器响应给用户
3、组件
二、怎么用
1、使用步骤
(1)引入相关依赖jar包
(2)在wel.xml中,配置SpringMVC的前端控制器DispatcherServlet
示例:
- <?xml version="1.0" encoding="UTF-8"?>
- <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee"
- xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
- <servlet>
- <servlet-name>springmvc</servlet-name>
- <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
- <!-- 指定Springmvc的配置文件,不指定时,默认找 /WEB-INF/[servlet-name]-servlet.xml -->
- <init-param>
- <param-name>contextConfigLocation</param-name>
- <param-value>classpath:springmvc.xml</param-value>
- </init-param>
- </servlet>
- <servlet-mapping>
- <servlet-name>springmvc</servlet-name>
- <!-- / 拦截所有请求,/* 拦截所有,包括页面 -->
- <url-pattern>/</url-pattern>
- </servlet-mapping>
- </web-app>
(3)配置文件 springmvc.xml
示例:
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns="http://www.springframework.org/schema/beans"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xmlns:mvc="http://www.springframework.org/schema/mvc"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-4.2.xsd
- http://www.springframework.org/schema/aop
- http://www.springframework.org/schema/aop/spring-aop-4.2.xsd
- http://www.springframework.org/schema/tx
- http://www.springframework.org/schema/tx/spring-tx-4.2.xsd ">
- <!-- 1. 配置组件扫描包 -->
- <context:component-scan base-package="cn.demo.controller" />
- <!-- 2. 配置处理器映射器 -->
- <!-- <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping" /> -->
- <!-- 3. 配置处理器适配器 -->
- <!-- <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/> -->
- <!-- 配置注解驱动:自动加载RequestMappingHandlerMapping和RequestMappingHandlerAdapter,代替映射器和适配器的配置-->
- <mvc:annotation-driven />
- <!-- 4. 配置视图解析器 -->
- <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
- <!-- 逻辑视图名前缀 -->
- <property name="prefix" value="/WEB-INF/jsp/" />
- <!-- 逻辑视图名后缀 -->
- <property name="subfix" value=".jsp" />
- </bean>
- </beans>
(4)编写处理器
示例:
- @Controller
- public class HelloWorldController {
- @RequestMapping(value="/helloworld", method=RequestMethod.GET)
- public String helloworld(){
- System.out.println("hello,world");
- return "success";
- }
- }
(5)编写视图,/WEB-INF/jsp/success.jsp
2、相关注解
三、数据处理
1、请求参数绑定
2、响应数据处理
3、HttpMessageConverter<T> 转换器
将请求数据转换为一个对象(类型为 T),将对象(类型为 T)转换为响应数据。
(1)两种使用方法
@RequestBody / @ResponseBody 对处理方法进行标注。
HttpEntity<T> / ResponseEntity<T> 作为处理方法的入参或返回值。
(2)原理
Spring 首先根据请求头或响应头的 Accept 属性选择匹配的 HttpMessageConverter, 再根据参数类型或泛型类型,过滤得到匹配的 HttpMessageConverter, 若找不到可用的 HttpMessageConverter 将报错。
四、拦截器
配置自定义拦截器示例:
- <mvc:interceptors>
- <!—默认拦截所有请求-->
- <!—方式一:声明自定义拦截器对象 -->
- <bean id="firstHandlerInterceptor" class="com.demo.springmvc.interceptors.FirstHandlerInterceptor"></bean>
- <!—方式二:引用有@Component的拦截器-->
- <ref bean=”firstHandlerInterceptor”>
- </mvc:interceptors>
配置多个拦截器示例:
- <mvc:interceptors>
- <!-- 声明自定义拦截器 -->
- <bean id="firstHandlerInterceptor" class="com.demo.springmvc.interceptors.FirstHandlerInterceptor"></bean>
- <!-- 配置拦截器拦截方式-->
- <mvc:interceptor>
- <!— 要拦截的请求 -->
- <mvc:mapping path="/empList"/>
- <!—不拦截的请求,如登录-->
- <mvc:exclude-mapping path="/login"/>
- <bean id="secondHandlerInterceptor" class="com.demo.springmvc.interceptors.SecondHandlerInterceptor"></bean>
- </mvc:interceptor>
- </mvc:interceptors>