三大框架(ssh)学习——Struts2工作流程分析
Struts2工作流程分析
STRUTS2框架内部流程
1. 客户端发送请求的tomcat服务器。服务器接受,将HttpServletRequest传进来。
2. 请求经过一系列过滤器(如:ActionContextCleanUp、SimeMesh等)
3. FilterDispatcher被调用。FilterDispatcher调用ActionMapper来决定这个请求是否要调用某个Action
4. ActionMapper决定调用某个ActionFilterDispatcher把请求交给ActionProxy
5. ActionProxy通过Configuration Manager查看struts.xml,从而找到相应的Action类
6. ActionProxy创建一个ActionInvocation对象
7. ActionInvocation对象回调Action的execute方法
8. Action执行完毕后,ActionInvocation根据返回的字符串,找到对应的result。然后将Result内容通过HttpServletResponse返回给服务器。
Struts2的线程安全问题
Struts1中所有的Action都只有一个实例,被反复的调用。Struts2中的Action处理一次请求会生成一个实例,这些实例彼此完全独立,使用完毕后就立马销毁。
struts1中的Action线程不安全,一般将不能有可写的属性(即将Action设计成无状态类)。
Struts2中的Action线程安全,可以任意设置属性!