1 SpringMVC 应用

1.1 SpringMVC 简介

  1. Spring MVC 是作用于传统三层架构(表现层、业务层、Dao层)的表现层框架。

Spring MVC 不同于MVC模式,MVC模式指的是:M(模型),V(视图),C(控制器)。

  1. Spring MVC 本质上可以认为是对servlet的封装。

    1.2 SpringMVC 流程

    开发过程

  2. 配置DispatcherServlet前端控制器

  3. 开发处理具体业务逻辑的Handler(@Controller、@RequestMapping)
  4. xml配置⽂件配置controller扫描,配置springmvc三⼤件
  5. 将xml⽂件路径告诉springmvc(DispatcherServlet)

    处理流程

    image.png

  6. ⽤户发送请求⾄前端控制器DispatcherServlet

  7. DispatcherServlet收到请求调⽤HandlerMapping处理器映射器
  8. 处理器映射器根据请求Url找到具体的Handler(后端控制器),⽣成处理器对象及处理器拦截 器(如果 有则⽣成)⼀并返回DispatcherServlet
  9. DispatcherServlet调⽤HandlerAdapter处理器适配器去调⽤Handler
  10. 处理器适配器执⾏Handler
  11. Handler执⾏完成给处理器适配器返回ModelAndView
  12. 处理器适配器向前端控制器返回 ModelAndView,ModelAndView 是SpringMVC 框架的⼀个 底层对 象,包括 Model 和 View
  13. 前端控制器请求视图解析器去进⾏视图解析,根据逻辑视图名来解析真正的视图
  14. 视图解析器向前端控制器返回View
  15. 前端控制器进⾏视图渲染,就是将模型数据(在 ModelAndView 对象中)填充到 request 域
  16. 前端控制器向⽤户响应结果

1.3 SpringMVC九大组件

  • HandlerMapping(处理器映射器)

HandlerMapping 是用来查找 Handler 的,也就是处理器,具体的表现形式可以是类,也可以是 ⽅法。
比如,标注了@RequestMapping的每个⽅法都可以看成是⼀个Handler。Handler负责具 体实际的请求处理,在请求到达后,HandlerMapping 的作⽤便是找到请求相应的处理器 Handler 和 Interceptor.

  • HandlerAdapter(处理器适配器)

HandlerAdapter 是⼀个适配器。因为 Spring MVC 中 Handler 可以是任意形式的,只要能处理请 求即可。
但是把请求交给 Servlet 的时候,由于 Servlet 的⽅法结构都是doService(HttpServletRequest req, HttpServletResponse rsp)形式的,要让固定的 Servlet 处理⽅法调⽤Handler来进⾏处理,便是 HandlerAdapter 的职责。

  • HandlerExceptionResolver

HandlerExceptionResolver ⽤于处理 Handler 产⽣的异常情况。它的作⽤是根据异常设置 ModelAndView,之后交给渲染⽅法进⾏渲染,渲染⽅法会将 ModelAndView 渲染成⻚⾯。

  • ViewResolver

ViewResolver即视图解析器,⽤于将String类型的视图名和Locale解析为View类型的视图,只有⼀ 个resolveViewName()⽅法。从⽅法的定义可以看出,Controller层返回的String类型视图名 viewName 最终会在这⾥被解析成为View。View是⽤来渲染⻚⾯的,也就是说,它会将程序返回 的参数和数据填⼊模板中,⽣成html⽂件。ViewResolver 在这个过程主要完成两件事情: ViewResolver 找到渲染所⽤的模板(第⼀件⼤事)和所⽤的技术(第⼆件⼤事,其实也就是找到 视图的类型,如JSP)并填⼊参数。默认情况下,Spring MVC会⾃动为我们配置⼀个 InternalResourceViewResolver,是针对 JSP 类型视图的。

  • RequestToViewNameTranslator

RequestToViewNameTranslator 组件的作⽤是从请求中获取 ViewName.因为 ViewResolver 根据 ViewName 查找 View,但有的 Handler 处理完成之后,没有设置 View,也没有设置 ViewName, 便要通过这个组件从请求中查找 ViewName。

  • LocaleResolver

ViewResolver 组件的 resolveViewName ⽅法需要两个参数,⼀个是视图名,⼀个是 Locale。 LocaleResolver ⽤于从请求中解析出 Locale,⽐如中国 Locale 是 zh-CN,⽤来表示⼀个区域。这 个组件也是 i18n 的基础。

  • ThemeResolver

ThemeResolver 组件是⽤来解析主题的。主题是样式、图⽚及它们所形成的显示效果的集合。 Spring MVC 中⼀套主题对应⼀个 properties⽂件,⾥⾯存放着与当前主题相关的所有资源,如图 ⽚、CSS样式等。创建主题⾮常简单,只需准备好资源,然后新建⼀个“主题名.properties”并将资 源设置进去,放在classpath下,之后便可以在⻚⾯中使⽤了。SpringMVC中与主题相关的类有 ThemeResolver、ThemeSource和Theme。ThemeResolver负责从请求中解析出主题名,ThemeSource根据主题名找到具体的主题,其抽象也就是Theme,可以通过Theme来获取主题和 具体的资源。

  • MultipartResolver

MultipartResolver ⽤于上传请求,通过将普通的请求包装成 MultipartHttpServletRequest 来实 现。MultipartHttpServletRequest 可以通过 getFile() ⽅法 直接获得⽂件。如果上传多个⽂件,还 可以调⽤ getFileMap()⽅法得到Map这样的结构,MultipartResolver 的作⽤就 是封装普通的请求,使其拥有⽂件上传的功能。

  • FlashMapManager

FlashMap ⽤于重定向时的参数传递,⽐如在处理⽤户订单时候,为了避免重复提交,可以处理完 post请求之后重定向到⼀个get请求,这个get请求可以⽤来显示订单详情之类的信息。这样做虽然 可以规避⽤户重新提交订单的问题,但是在这个⻚⾯上要显示订单的信息,这些数据从哪⾥来获得 呢?因为重定向时么有传递参数这⼀功能的,如果不想把参数写进URL(不推荐),那么就可以通 过FlashMap来传递。只需要在重定向之前将要传递的数据写⼊请求(可以通过 ServletRequestAttributes.getRequest()⽅法获得)的属性OUTPUT_FLASH_MAP_ATTRIBUTE 中,这样在重定向之后的Handler中Spring就会⾃动将其设置到Model中,在显示订单信息的⻚⾯上就可以直接从Model中获取数据。FlashMapManager 就是⽤来管理 FalshMap的。

1.4 SpringMVC的url-pattern的配置

url-pattern配置的三种方式:

  1. 带后缀,比如*.action`` *.do ``*.aaa

该种方式比较精确、方便,在以前和现在企业中都有很大的使用比例

  1. 使用/

不会拦截 .jsp,但是会拦截.html等静态资源(静态资源:除了servlet和jsp之外的js、css、png等)

  1. 为什么配置为/ 会拦截静态资源???
    因为tomcat容器中有一个web.xml(父),你的项目中也有一个web.xml(子),是一个继承关系父 web.xml中有一个DefaultServlet, url-pattern是一个/此时我们自己的web.xml中也配置了一 个/, 覆写了父web.xml的配置
  2. 为什么不拦截.jsp呢?
    因为父web.xml中有一个JspServlet,这个servlet拦截.jsp文件,而我们并没有覆写这个配置,
    所以springmvc此时不拦截.jsp.jsp的处理交给了tomcat
  3. 自定义
    1. 使用/*拦截所有,包括.jsp

      静态资源配置:

  1. <mvc:default-servlet-handler/>

原理:添加该标签配置之后,会在SpringMVC上下文中定义一个DefaultServletHttpRequestHandler对象这个对象如同一个检查人员,对进入DispatcherServlet的url请求进行过滤筛查,如果发现是一个静态资源请求那么会把请求转由web应用服务器(tomcat)默认的DefaultServlet来处理,如果不是静态资源请求,那么继续由SpringMVC框架处理。

  1. <mvc:resources location="classpath:/" mapping="/resources/**"/>

<mvc:resources location="/WEB-INF/js/" mapping="/js/**"/>
SpringMVC框架自己处理静态资源
mapping:约定的静态资源的url规则
location:指定的静态资源的存放位置

2 SpringMVC高级应用

2.1 拦截器

2.1.1 监听器、过滤器、拦截器 比较

  • 过滤器(Filter):对Request请求起到过滤的作⽤,作⽤在Servlet之前,如果配置为/*可以对所 有的资源访问(servlet、js/css静态资源等)进⾏过滤处理
  • 监听器(Listener):实现了javax.servlet.ServletContextListener 接⼝的服务器端组件,它随 Web应⽤的启动⽽启动,只初始化⼀次,然后会⼀直运⾏监视,随Web应⽤的停⽌⽽销毁
    • 作⽤⼀:做⼀些初始化⼯作,web应⽤中spring容器启动ContextLoaderListener
    • 作⽤⼆:监听web中的特定事件,⽐如HttpSession,ServletRequest的创建和销毁;变量的创建、 销毁和修改等。可以在某些动作前后增加处理,实现监控,⽐如统计在线⼈数,利⽤ HttpSessionLisener等
  • 拦截器(Interceptor):是SpringMVC、Struts等表现层框架⾃⼰的,不会拦截 jsp/html/css/image的访问等,只会拦截访问的控制器⽅法(Handler)

spring mvc.jpg

2.1.2 拦截器执行流程及实现

  1. 实现HandlerInterceptor方法

image.png

  1. 配置xml,注册拦截器

image.png

2.1.3 多个拦截器的执行流程

在 Web 应用中通常需要有多个拦截器同时工作,这时它们的 preHandle 方法将按照配置文件中拦截器的配置顺序执行,而它们的 postHandle 方法和 afterCompletion 方法则按照配置顺序的反序执行。
如下图:
spring mvc-多拦截器执行流程.jpg

2.2 异常处理

image.png

2.3 重定向

image.png