参考:http://www.cnblogs.com/fidelQuan/p/3365815.html
从Structs2角度上理解MVC
在Structs2中,模型层对应业务逻辑组件,它通常用于实现业务逻辑及与底层数据库的交互。
视图层对应视图组件,通常是指JSP页面,或者其他。
控制层对应系统核心控制器和业务逻辑控制器。系统核心控制器为Structs2框架提供的FilterDispatcher,它是一个起过滤的类,如过滤掉一些非法的url,能够根据请求自动调用相应的Action。而业务逻辑控制器是指开发人员自行定义的一系列Action,在Action中负责调用相应的业务逻辑组件来完成处理。
Structs2的执行原理
1) 客户端初始化一个指向Servlet容器(例如Tomcat)的请求
2 )这个请求经过一系列的过滤器(Filter)(这些过滤器中有一个叫做ActionContextCleanUp的可选过滤器,这个过滤器对于Struts2和其他框架的集成很有帮助,例如:SiteMesh Plugin)
3 )接着FilterDispatcher被调用,FilterDispatcher询问ActionMapper来决定这个请是否需要调用某个Action
4 )如果ActionMapper决定需要调用某个Action,FilterDispatcher把请求的处理交给ActionProxy
5 )ActionProxy通过Configuration Manager询问框架的配置文件,找到需要调用的Action类
6 )ActionProxy创建一个ActionInvocation的实例。
7 )ActionInvocation实例使用命名模式来调用,在调用Action的过程前后,涉及到相关拦截器(Intercepter)的调用。
8 )一旦Action执行完毕,ActionInvocation负责根据struts.xml中的配置找到对应的返回结果。返回结果通常是(但不总是,也可 能是另外的一个Action链)一个需要被表示的JSP或者FreeMarker的模版。在表示的过程中可以使用Struts2 框架中继承的标签。在这个过程中需要涉及到ActionMapper
这个过程可以如图所示: