目录
一、Struts2的工作原理
二、Spring MVC的工作原理
1)整体流程
2)核心流程
三、Struts2与Spring的区别
1、客户端(HttpServletRequest)发送请求
2、请求经过过滤器((可选过滤器)-->StrutsPrepareAndExecuteFilter(核心过滤器,struts1的核心过滤器是FilterDispatcher只过滤后缀为.action的请求 ) )
3、请求到达ActionMapper,通过它来决定调用哪个Action
4、当决定调用某个Action后,请求又会通过核心过滤器,核心过滤器把请求的处理交给ActionProxy
5、ActionProxy通过ConfigurationManager询问配置文件(Struts.xml),找到要调用的Action类。
6、之后ActionProxy创建一个ActionInvocation的反向实例
7、经过拦截器(interceptor), 通过ActionInvocation的实例调用真正的Action
8、Action执行完毕,ActionInvocation创建Result并返回
9、Result经过JSP、拦截器之后,通过HttpServletResponse返回到客户端
1、 首先用户发送请求到前端控制器,前端控制器根据请求信息(如 URL)来决定选择哪一个页面控制器进行处理并把请求委托给它,即以前的控制器的控制逻辑部分;图中的 1、2 步骤;
2、 页面控制器接收到请求后,进行功能处理,首先需要收集和绑定请求参数到一个对象,这个对象在 Spring Web MVC 中叫命令对象,并进行验证,然后将命令对象委托给业务对象进行处理;处理完毕后返回一个 ModelAndView(模型数据和逻辑视图名);图中的 3、4、5 步骤;
3、 前端控制器收回控制权,然后根据返回的逻辑视图名,选择相应的视图进行渲染,并把模型数据传入以便视图渲染;图中的步骤 6、7;
4、 前端控制器再次收回控制权,将响应返回给用户,图中的步骤 8;至此整个结束。
具体步骤:
第一步:客户端了浏览器发起请求到前端控制器(DispatcherServlet)
第二步:前端控制器请求HandlerMapping查找 Handler (可以根据xml配置、注解进行查找)
第三步:处理器映射器HandlerMapping向前端控制器返回Handler,HandlerMapping会把请求映射为HandlerExecutionChain对象(包含一个Handler处理器(页面控制器Controller?)对象,多个HandlerInterceptor拦截器对象),通过这种策略模式,很容易添加新的映射策略
第四步:前端控制器调用处理器适配器去执行Handler
第五步:处理器适配器HandlerAdapter将会根据适配的结果去执行Handler
第六步:Handler执行完成给适配器返回ModelAndView
第七步:处理器适配器向前端控制器返回ModelAndView (ModelAndView是springmvc框架的一个底层对象,包括 Model和view)
第八步:前端控制器请求视图解析器去进行视图解析 (根据逻辑视图名解析成真正的视图(jsp)),通过这种策略很容易更换其他视图技术,只需要更改视图解析器即可
第九步:视图解析器向前端控制器返回View
第十步:前端控制器进行视图渲染 (视图渲染将模型数据(在ModelAndView对象中)填充到request域)
第十一步:前端控制器向用户响应结果
1、spring mvc的入口是servlet,而struts2的入口是一个filter。
2、spring mvc的性能比struts2高,由于struts2中存在值栈。
3、spring mvc 集成了Ajax,只需@ResponseBody注解即可。而struts2使用ajax就不是那么方便了。
4、Struts2框架是类级别的拦截,每次请求创建一个Action,方法间共享request域中的数据,它只能使用多例模式管理Action,spring mvc是方法级别的拦截,方法间独享requset的数据,可以使用单例模式管理Controller。