学习目标
- 熟悉SpringMVC六大组件的作用及使用
- 掌握ssm开发框架
- 掌握SpringMVC对返回值的处理
- 掌握SpringMVC对参数的处理
- 理解REST和RESTful,掌握SpringMVC对于RESTful的支持
- 掌握SpringMVC拦截器的应用
- 掌握SpringMVC中基于CORS的跨域解决方案
- 掌握Spring中的父子容器
- 了解SpringMVC的Mock测试
- 了解ControllerAdvice类的开发
ModelAttribute
、InitBinder
、ExceptionHandler
- 了解SpringMVC异常处理
- 了解SpringMVC中的
get
、post
请求乱码和响应乱码 - 了解SpringMVC中非注解开发
依赖
org.springframework:spring-webmvc:5.0.7.RELEASE
javax.servlet:servlet-api:2.5:provided
SSM框架整合
web.xml
<!--配置前端控制器-->
<servlet>
<servlet-name>ssm</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/springmvc.xml</param-value>
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>ssm</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--指定持久层和业务层的spring配置文件路径-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/applicationContext-*.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
springmvc.xml
<!--配置处理Bean的读取-->
<!--扫描controller注解,多个包中间用逗号分开-->
<context:component-scan base-package="xct.controller"/>
<!--配置三大组件之处理器适配器和处理器映射器-->
<!--内置了RequestMappingHandlerMapping和RequestMappingHandlerAdapt等组件注册-->
<mvc:annotation-driven/>
<!--配置三大组件之视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
applicationContext-dao.xml
<context:property-placeholder location="classpath:db.properties"/>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<property name="maxActive" value="30"/>
<property name="maxIdle" value="5"/>
</bean>
<bean id="sqSessionFactory"
class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="typeAliasesPackage" value="xct"/>
</bean>
返回值的处理
- 不用注解修饰
- 返回
ModelAndView
- 返回
void
- 返回
String
- 返回视图
return "路径"
- 重定向
return "redirect:路径"
- 转发
return "forward:路径"
- 返回视图
- 返回
- 使用注解修饰
@ResponseBody
- 使用内置的9种
HttpMessageConverter
进行匹配,找到合适的Converter进行处理 HttpMessageConverter
处理逻辑分为两步:- 指定
HttpServletResponse
的ContentType
值 - 将转换之后的数据放到
HttpServletResponse
对象的响应体返回到页面
- 指定
- 使用内置的9种
参数绑定
- 简单类型
- 自动绑定:形参名称与参数名保持一致
@RequestParam
手动绑定
- POJO类型
- 参数名称与POJO属性名称一致
- 集合数组
- 批量简单类型数据:简单类型只能使用数组接收不能用
List
- 批量POJO数据:使用
List
接收,List
必须是一个方法参数类中的属性,参数名xxxList[i].yyy
或xxxMap[yyy]
- 批量简单类型数据:简单类型只能使用数组接收不能用
- 日期类型
- 自定义
Convter
- 自定义
<mvc:annotation-driven conversion-service="conversionService"/>
<bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
<property name="converters">
<set>
<bean class="xct.DataConvter"/>
</set>
</property>
</bean>
- 文件类型
- 依赖
commons-fileupload:commons-fileupload:1.3.3
- 配置
MultipartResolver
- 依赖
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="5242880"/>
</bean>
Restful支持
- REST指的是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是Restful
- 特点一:用请求方法区分不同资源
- 特点二:URL路劲变量
- 特点三:一种资源有多种表述
- 使用
ContentNegotiationManager
这个内容协商管理器来实现- 三种内容协商方式
- 扩展名:比如
.json
返回json数据,.xml
返回xml数据 - 请求参数:默认是
format
- 请求头设置
Accept
参数
- 扩展名:比如
- 三种内容协商方式
- 使用
- 伴随问题静态资源访问处理
mvc:resource
- 如果在
DispatcherServlet
中设置url-pattern
为/
则必须对静态资源进行访问处理
- 如果在
<mvc:resource location="/js/" mapping="/js/"/>
<mvc:resource location="/css/" mapping="/css/"/>
<!--Spring会把mapping映射到ResourceHttpRequestHandler,这样静态资源在经过DispatcherServlet转发时就可以找到对应的Handler了。-->
配置拦截器
- 实现
HandlerInterceptor
接口 - 配置拦截器
<mvc:interceptors>
<!--拦截所有请求-->
<bean class="xct.MyInterceptor"/>
<mvc:interceptor>
<!--拦截指定路径-->
<mvc:mapping path="/orders/**"/>
<bean class="xct.MyInterceptor1"/>
</mvc:interceptor>
</mvc:interceptors>
基于CORS的跨域解决方案
浏览器处于安全考虑,设置了
同源策略
,简单理解就是DNS域名,端口号,协议完全相同称为同源
-
如何解决跨域
- 解决跨域主要考虑两个方面
- 一个是臂铠Ajax请求方式
- 一个是解决同源限制问题
-
解决跨域的方式有多种
- 基于JavaScript标签的
src
方式 - 基于Jquery的JSONP方式
- 基于CORS的方式
- 基于JavaScript标签的
-
JSONP和CORS的区别
- JSONP只能解决GET方式提交
- CORS支持GET、POST方式
-
CORS是一个W3C标准,全称是跨域资源共享(
Cross-origin resource sharing
)
它允许浏览器向跨源服务器发出XMLHttpRequest
请求,从而克服了AJAX只能同源使用的限制
需要浏览器和服务器同时支持。目前所有浏览器都支持该功能,IE浏览器不能低于IE10
-
CORS原理
- 请求头注入
Origin
- 服务器需要向响应头注入
Access-Control-Allow-Origin
- 浏览器检测到
Access-Control-Allow-Origin
,则可以跨域
- 请求头注入
-
SpringMVC实现
@CrossOrigin
加到类或方法上
<!--所有请求都支持跨域-->
<mvc:cors>
<mvc:mapping path="/**"/>
</mvc:cors>
父子容器
ContextLoaderListener
加载的配置项会形成一个父容器DispatcherServlet
加载的配置项会形成一个子容器- 子容器可依获取父容器配置项,父容器无法获取子容器配置项,
例如父容器创建的类无法依赖注入子容器管理的类
- 如果只用一个配置文件就不会出现父子容器问题