1、Spring MVC流程图
2、Spring MVC数据绑定和转换
一、Spring MVC流程概述
以前一直使用Struts做MVC项目,然后再结合Spring做bean管理、AOP、以及事务的配置,但自从Spring MVC推出以后,它大大的简化了MVC的配置,对于web MVC的项目开发有了质的飞跃。下面简要的看下Spring MVC的主要流程。
1、当用户通过浏览器发送web请求时,首先接受到的是应用服务器,比如tomcat,应用服务器通过协议解析等一系列动作后,将请求对象HttpServletRequest交给DispatcherServlet,DispatcherServlet是Spring MVC的核心入口。
2、DispatcherServlet收到request请求后会在doService方法里设置一些request相关的属性,比如applicationContext,支持国际化用的LocalResolver等,然后将request交由请求处理适配器
3、Spring 在初始化applicationContext的阶段会将请求uri与请求处理器进行一个映射,在运行期由请求处理适配器HandlerAdapter通过request对象找到对应的处理器
HandlerMethod,Spring MVC中的Handler是Object类型,实际上是在Controller上配了@ReqquestMapping的方法,因此默认提供的都是HandlerMethod对象作为请求处理器。
4、Handler处理请求,即调用对应的业务方法逻辑后将返回ModelAndView视图对象,然后调用
HandlerExecutionChain的
applyPostHandle方法处理视图对象
5、Spring MVC使用视图解析器解析ModelAndView对象,然后生成对应的页面交由DispatcherServlet,由它将响应写回给客户端,这样就基本完成了整个请求的处理 。
下面来看看DispatcherServlet的类图结构
DispatcherServlet继承了FrameworkServlet,FrameworkServlet实现了servlet接口,同时实现了Spring的ApplicationContextAware拥有了设置上下文的能力。
DispatcherServlet聚合了HandlerExcutionChain和HandlerAdapter,其中HandlerExcutionChain聚合了HandlerInterceptor,HandlerExcutionChain的主要作用就是在执行具体的业务方法的前后执行注入的拦截器。
HandlerAdapter是一个处理器的适配器或者说是一个选择器。读者可能会问,在HandlerExcutionChain里不是有handler吗,为什么不直接使用HandlerExcutionChain执行handler而非要再套个Adapter? 其实是因为Spring MVC支持多种的处理方式,比如直接写一个类,在方法里添加注解@RequestMapping就可以生成一个处理器,同时还支持原生的Servlet等方式,所以在处理一个请求时虽然知道了执行业务处理的方法,但是具体执行时应该设置怎样的上下文,执行前需要做这样的准备是不一样的。所以有了Adapter这一层。通过HandlerAdapter.support(Object handler)来判断是否可以执行本次请求处理器。
当DispatcherServlet确定使用哪个HandlerAdapter之后,就是调用handle()方法去执行业务逻辑,然后返回ModelAndView对象供视图层使用。
得到ModelAndView后通过
processDispatchResult(
processedRequest
,
response
,
mappedHandler
,
mv
,
dispatchException
);方法处理视图对象,这里会通过视图解析器
ViewResolver把ModelAndView解析成View对象,然后
调用View的render方法找到生成要返回的response对象并返回给用户。
二、Spring MVC数据绑定及转换
Spring MVC对于的请求数据的绑定处理是在执行Handler方法时进行的。下面看看数据绑定相关的类图结构
图中标深黄色的是主要的类,接下来具体的分析一下这些类
1、RequestMappingHandlerAdapter:它在Spring MVC中是具体执行handler的,它在invokeHanlderMethod方法中通过反射执行Handler,在具体执行之前它先把请求传过来的数据做转换和绑定。通过类图可以知道它是通过WebDataBinderFactory来进行数据绑定的。
2、DataBinder是Spring MVC数据绑定的核心部件,它通过装配上下文中的ConversionService组件进行数据类型转换、数据格式化工作。可以看到它的实现类GenericConversionService里聚合了Converters,其中Converters就装配了一个gloBalConverters Set集合和一个Map集合,真正运行的时候这里会有一堆的转换类,其中ObjectToStringConverter就是其中的一个,其实JDK本身也提供了一个类似的转换工具就是
PropertyEditor,但是它的核心功能是将一个字符串转为对象,并不适用于两个对象之间的转换,同时对于源对象的上下文信息(注解、宿主类结构等)不敏感,无法在转换的时候通过这些信息实现一些逻辑,因此Spring新建了一套转换体系。
下图是DataBinder的工作机制示意图