MVC

即 Model-View-Controller,是一种复合模式。

  • Model:模型。封装了应用程序数据所有基于这些数据的操作,并且通常它们由 POJO 组成。
  • View:视图。主要用于呈现模型数据,并且通常它生成客户端的浏览器可以解释的 HTML 输出。
  • Controller:控制器。主要用于处理用户请求,并且构建合适的模型并将其传递到视图呈现。

其中,模型利用 “观察者模式” 让 Controller 和视图随最新的状态改变而更新;View 和 Controller 实现 “策略模式”,控制器是视图的行为,若希望有不同的行为,可直接换一个控制器;视图内部利用“组合模式”。

优点:

  • 三个模块可共享一个模型,大大提高代码的可重用性
  • 三个模块相互独立,耦合性较低
  • Controller 提高了应用程序的灵活性,使用 Controller 可连接不同模型和视图去满足用户的需求

    SpringMVC

    SpringMVC 是一种基于 Java,实现了 Web MVC 设计模式,请求驱动类型的轻量级 Web 框架。优点如下:

  • 基于组件技术。全部的应用对象,无论是控制器、视图,还是业务对象之类都是 Java 组件。并且和 Spring 提供的其他基础结构紧密集成;

  • 不依赖于 Servlet API;
  • 可以任意使用各种视图技术,而不仅仅局限于jsp;
  • 支持各种请求资源的映射策略;
  • 易扩展。

    原理

    SpringMVC 框架是以请求为驱动,围绕 Servlet 设计,将请求发给控制器,然后通过模型对象,分派器来展示请求结果视图。 其中核心类是 DispatcherServlet,它是一个 Servlet,顶层实现 Servlet 接口。

原理图如下:
Spring MVC - 图1

Spring Web 模型-视图-控制(MVC)框架是围绕 DispatcherServlet 设计的,DispatcherServlet 用来处理所有的 HTTP 请求和响应。Spring Web MVC DispatcherServlet 的请求处理的工作流程如下图所示:
image.png
下面是对应于 DispatcherServlet 传入 HTTP 请求的事件序列:

  1. 收到一个 HTTP 请求后,DispatcherServlet 根据 HandlerMapping 来选择并且调用适当的控制器。
  2. 控制器接受请求,并基于使用的 GET 或 POST 方法来调用适当的 service 方法。Service 方法将设置基于定义的业务逻辑的模型数据,并返回视图名称到 DispatcherServlet 中。
  3. DispatcherServlet 会从 ViewResolver 获取帮助,为请求检取定义视图。
  4. 一旦确定视图,DispatcherServlet 将把模型数据传递给视图,最后呈现在浏览器中。

上面所提到的所有组件,即 HandlerMapping、Controller 和 ViewResolver 是 WebApplicationContext 的一部分,而 WebApplicationContext 是带有一些对 web 应用程序必要的额外特性的 ApplicationContext 的扩展。

重要组件

1、DispatcherServlet

  • 说明:前端控制器,不需要工程师开发,由 SpringMVC 框架提供。
  • 作用:Spring MVC 的入口。接收请求,响应结果,相当于转发器,中央处理器。DispatcherServlet是整个流程控制的中心,由它调用其它组件处理用户的请求,DispatcherServlet 降低了组件之间的耦合度

2、HandlerMapping

  • 说明:处理器映射器,不需要工程师开发,由 SpringMVC 框架提供。
  • 作用:根据请求的 url 查找 Handler。SpringMVC 提供了不同的映射器实现不同的映射方式,例如:配置文件方式,实现接口方式,注解方式等。

3、HandlerAdapter

  • 说明:处理器适配器。
  • 作用:按照特定规则(HandlerAdapter要求的规则)执行 Handler。通过 HandlerAdapter 对处理器进行执行,这是适配器模式的应用,通过扩展适配器可以对更多类型的处理器进行执行。

4、Handler

  • 说明:处理器,需要工程师开发。
  • 注意:编写 Handler 时按照 HandlerAdapter 的要求的规则去做,这样适配器才可以去正确执行 Handler, Handler 是后端控制器,在 DispatcherServlet 的控制下 Handler 对具体的用户请求进行处理。 由于 Handler 涉及到具体的用户业务请求,所以一般情况需要工程师根据业务需求开发 Handler。

5、ViewResolver

  • 说明:视图解析器,不需要工程师开发,由 SpringMVC 框架提供。
  • 作用:进行视图解析,根据逻辑视图名解析成真正的视图。ViewResolver 负责将处理结果生成 View 视图, ViewResolver 首先根据逻辑视图名解析成物理视图名即具体的页面地址,再生成 View 视图对象,最后对View 进行渲染将处理结果通过页面展示给用户。 SpringMVC 框架提供了很多的 View 视图类型,包括:jstlView、freemarkerView、pdfView等。 一般情况下需要通过页面标签或页面模版技术将模型数据通过页面展示给用户,需要工程师根据业务需求开发具体的页面。

6、View

  • 说明:视图 View,需要工程师开发。
  • 作用:View 是一个接口,实现类支持不同的 View类型(jsp、freemarker、pdf…)