三大框架(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线程安全,可以任意设置属性!

猜你喜欢

转载自blog.csdn.net/weixin_38003467/article/details/83540461