struts的架构图
(1)提交请求
客户端通过HttpServletRequest向servlet容器(即tomcat)提交一个请求。
请求经过一系列的过滤器,例如图中的ActionContextCleanUp和Other filter(SlterMesh,etc)等,最后被struts的核心过滤器FilterDispatcher控制到。
注:核心控制器2.1.3版本之后,struts的filterDispatcher核心控制器变成了StrutsPrepareAndExecuteFilte,如图:
被核心控制器控制到之后才会访问Actionmapper来决定是否调用某个action(即用户是否要请求某个action)。如果是其他资源请求例如jsp页面,不会用到action。
(2)移交控制权
如果要用到action,核心控制器将控制权交给ActionProxy(即是action的代理)。
ActionProxy获得控制权之后通过ConfigurationManager对象加载核心配置文件struts.xml。
Struts的action在这个配置文件进行配置,所以要加载它。
(3)创建ActionInvocation的实例
如果在struts.xml找到需要调用的action, ActionProxy会创建一个ActionInvocation的实例。
(4)调用action前的拦截器
拦截器是struts2非常重要的概念,是核心功能实现。Struts中的大部分功能通过拦截器实现。
Actioninvocation包括创建的action实例,同时包括另外非常重要的一部分------拦截器。
调用action前后还会调用很多的拦截器。
在调用action之前会依次调用用户所定义的拦截器。
(5)调用action的业务方法进行业务处理
当把action前的拦截器执行完之后才会调用action的业务方法进行业务处理,
然后返回一个Result(业务方法对应String类型的返回值,即是字符串,例如SUCCESS,INPUT,ERROR,NONE,LOGIN和用户自己在struts对应定义result标签name属性的值)
(6)匹配result
然后根据返回的字符串来调度我们的视图来匹配我们的struts.xml中对应action标签中的result标签。
一般来说返回一个jsp的页面,或者调用另外某一个action。
(7)反向执行拦截器
当返回视图之后并没有真正响应用户,还需要把执行过的拦截器倒过来反向执行一遍。
(8)响应客户端
当这些拦截器被反向执行之后,通过HttpServletResponse响应客户端的请求。
struts2框架执行流程大致这样,如有不对,敬请指出,谢谢!