SpringMVC详细运行流程图
具体执行步骤如下:
1、 首先用户发送请求—>前端控制器,前端控制器根据请求信息(如URL)来决定选择哪一个页面控制器进行处理并把请求委托给它,即以前的控制器的控制逻辑部分;图中的1、2步骤;
2、 页面控制器接收到请求后,进行功能处理,首先需要收集和绑定请求参数到一个对象,这个对象在Spring Web MVC中叫命令对象,并进行验证,然后将命令对象委托给业务对象进行处理;处理完毕后返回一个ModelAndView(模型数据和逻辑视图名);图中的3、4、5步骤;
3、 前端控制器收回控制权,然后根据返回的逻辑视图名,选择相应的视图进行渲染,并把模型数据传入以便视图渲染;图中的步骤6、7;
4、 前端控制器再次收回控制权,将响应返回给用户,图中的步骤8;至此整个结束。
具体提现在DispatcherServlet代码中的执行过程:
核心架构的具体流程步骤如下:
1、 首先用户发送请求—>DispatcherServlet,前端控制器收到请求后自己不进行处理,而是委托给其他的解析器进行处理,作为统一访问点,进行全局的流程控制;
2、 DispatcherServlet——>HandlerMapping, HandlerMapping将会把请求映射为HandlerExecutionChain对象(包含一个Handler处理器(页面控制器)对象、多个HandlerInterceptor拦截器)对象,通过这种策略模式,很容易添加新的映射策略;
protected HandlerExecutionChain getHandler(HttpServletRequest request) throws Exception
{
for (HandlerMapping hm : this.handlerMappings) {
...
HandlerExecutionChain handler = hm.getHandler(request);
....
}
}
3、 DispatcherServlet——>HandlerAdapter,HandlerAdapter将会把处理器包装为适配器,从而支持多种类型的处理器,即适配器设计模式的应用,从而很容易支持很多类型的处理器;
HandlerAdapter ha = getHandlerAdapter(mappedHandler.getHandler());
4、 HandlerAdapter——>处理器功能处理方法的调用,HandlerAdapter将会根据适配的结果调用真正的处理器的功能处理方法,完成功能处理;并返回一个ModelAndView对象(包含模型数据、逻辑视图名);
try {
// Actually invoke the handler.
mv = ha.handle(processedRequest, response, mappedHandler.getHandler());
}
5、 ModelAndView的逻辑视图名——> ViewResolver, ViewResolver将把逻辑视图名解析为具体的View,通过这种策略模式,很容易更换其他视图技术;
6、 View——>渲染,View会根据传进来的Model模型数据进行渲染,此处的Model实际是一个Map数据结构,因此很容易支持其他视图技术;
7、返回控制权给DispatcherServlet,由DispatcherServlet返回响应给用户,到此一个流程结束。
DispatcherServlet中使用的特殊的Bean
DispatcherServlet默认使用WebApplicationContext作为上下文
Controller:页面控制器。MVC中C的事情,用于对请求进行处理
HandlerMapping:请求到处理器之间的映射,映射成功,返回一个HandlerExecutionChain对象,包含一个Handler处理器,多个HandlerInterceptor对象,
HandlerAdapter:将处理器包装成适配器,从而支持多种类型的处理器Controller,使用适配器模式,从而容易支持很多类型的处理器。
ViewResolver:把具体逻辑视图名解析成具体的View,使用策略模式,容易更换其他视图。如InternalResourceViewResolver将逻辑视图名映射为jsp视图;
MultipartResolver:文件上传解析,用于支持文件上传;
- HandlerExceptionResolver:处理器异常解析,可以将异常映射到相应的统一错误界面,从而显示用户友好的界面(而不是给用户看到具体的错误信息)
Controller解析
控制器主要负责功能处理部分:
1、收集、验证请求参数并绑定到命令对象;
2、将命令对象交给业务对象,由业务对象处理并返回模型数据;
3、返回ModelAndView(Model部分是业务对象返回的模型数据,视图部分为逻辑视图名)。
控制器接口Controller,包含一个方法 handlerRequest(),返回ModelAndView对象
HandlerInterceptor拦截器解析
类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理,三个回调方法。
preHandle:预处理方法,Action之前执行,可以进行编码,安全控制等处理。方法参数中的Object handler是下一个拦截器。返回true表示继续流程,如继续下一个拦截器或者处理器,返回false表示流程中断,不会继续流程,需要通过response来产生响应。
postHandle:后处理方法。在生成视图之前处理。调用Service并返回了ModelAndView,但未进行页面渲染,还有机会进行修改ModelAndView,参数中的Object handler是下一个拦截器
afterCompletion:处理请求完毕的回调方法,最后已经渲染了页面之后才执行。,可用于释放资源,或者监控执行时间根据ex参数是否为null判断是否发生了异常进行日志记录等。参数中的Object Handler是下一个拦截器。类似于try-catch-finally中的finally,但仅调用处理器执行链中preHandle返回true的拦截器的afterCompletion。