图文解析Struts2框架执行流程

 

struts的架构图

(1)提交请求

客户端通过HttpServletRequest向servlet容器(即tomcat)提交一个请求。

请求经过一系列的过滤器,例如图中的ActionContextCleanUp和Other filter(SlterMesh,etc)等,最后被struts的核心过滤器FilterDispatcher控制到。其中在FilterDispatcher之前的过滤器,不是Struts2的部分,而是Tomcat自身的东西。包括后面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)反向执行拦截器

当返回视图之后并没有真正响应用户,因为所有拦截器只执行了前半部分,和Web基础学的Filter是一个道理,还有非常类似的doFilter()方法后面的代码还没执行!!!只有所有方法执行完毕后,客户端才会得到响应!!!也就是Filter执行完毕后,客户端才能够得到响应!!!

(8)响应客户端

当这些拦截器被反向执行之后,通过HttpServletResponse响应客户端的请求。

 

struts2框架执行流程大致这样,如有不对,敬请指出,谢谢!

 

转载地址

参考博客

http://www.cnblogs.com/jasonHome/p/5917991.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值