一、核心运行流程如下:
1.用户发送请求->DispatcherServlet,前端控制器收到请求后自己不进行处理,而是委托给其他的解析器处理,它作为统一访问点,进行全局的流程控制;
2.DispatcherServlet->HandlerMapping,HandlerMapping会把请求映射为HandlerExecutionChain对象;
3.DispatcherServlet->HandlerAdapter, HandlerAdapter把处理器包装为适配器,从而支持多种类型的处理器;
4.HandlerAdapter->处理器功能处理方法的调用,HandlerAdapter将会根据适配的结果调用真正的处理器的功能处理方法,完成功能处理,并返回一个ModelAndView对象(包含模型数据,逻辑视图名);
5.ModelAndView->ViewResolver,ViewResolver将把逻辑视图名解析为具体的View;
6.View->渲染,View根据传进来的Model模型数据进行渲染,此处的Model实际是一个Map数据结构(Key-Value);
7.返回控制权给DispatcherServlet,由DispatcherServlet返回响应给用户,至此,一个流程结束。
二、部分名词解释如下:
1.DispatcherServlet
DispatcherServlet是前端控制器设计模式的实现,提供Spring Web MVC的集中访问点,而且负责职责的分派,可以与Spring IOC无缝集成。
DispatcherServlet主要负责职责调度工作,主要用于控制流程,主要职责如下:
(1)文件上传解析,如果请求类型是multipart将通过MultipartResolver进行文件上下文解析;
(2)通过HandlerMapping将请求映射到处理器(返回一个HandleExecutionChain,它包括一个处理器,多个HandlerInterceptor拦截器);
(3)通过HandleAdapter支持多种类型的处理器(HandleerExecutionChain中的处理器);
(4)通过ViewResolver解析逻辑视图名到具体视图实现;
(5)本地化解析;
(6)渲染具体的视图等;
(7)如果执行过程中遇到异常将交给HandlerExceptionResolver来解析;
另外:ContextLoaderListener初始化上下文加载的Bean对于整个应用是共享的,DispatcherServlet初始化的上下文加载的Bean只是对Spring Web MVC有效的,如Controller,HandlerMapping,HandlerAdapter等,该初始化上下文应该只加载Web相关组件。
2.HandlerMapping
DispatcherServlet通过创建实现了HandlerMapping接口的对象后,完成了Url到Handler之间映射关系的注册,之后就可以调用getHandler方法,得到HandlerExecutionChain对象(包含一个Handler处理器对象,多个HandlerInterceptor拦截器对象) ,使用得到的Handler调用相应的控制器。通过这种策略模式,添加一个新的映射策略将会很容易。
3.Controller
控制器Controller负责处理由DispatcherServlet分发的请求,收集、验证请求参数并绑定到命令对象,将命令对象交给业务对象,由业务对象处理并返回模型数据,之后返回ModelAndView。
Controller与DispatcherServlet一起组成了一个MVC中完整的C(控制逻辑 + 功能处理)部分。