Struts2框架本身大致可以分为三个部分:核心控制器FilterDispatcher、业务控制器Action和用户实现的企业业务逻辑组件。
一、 核心控制器FilterDispatcher
1. 核心控制器FilterDispatcher是Struts2框架的基础,包含了框架内部的控制流程和处理机制。业务控制器Action和业务逻辑组件是需要用户来自己实现的。用户在开发Action和业务逻辑组件的同时,还需要编写相关的配置文件,供核心控制器FilterDispatcher来使用。
2. Struts2的工作流程与WebWork框架基本相同。Struts2框架按照模块来划分,可以分为Servlet Filters、Struts核心模块、拦截器和用户实现部分。Struts2框架结构图如下:
3. 一个请求在Struts2框架中的处理大概分为以下几个步骤:
1. 客户端提交一个(HttpServletRequest)请求。
2. 请求被提交到一系列(主要是三层)的过滤器(Filter),如:ActionContextCleanUp、再其他过滤器(SiteMesh等)、FilterDispatcher。
3. FilterDispatcher是控制器的核心,即MVC的Struts2实现中控制层(Controller)的核心。
4. FilterDispatcher询问ActionMapper是否需要调用某个Action来处理这个(HttpServletRequest)请求,如果ActionMapper决定需要调用某个Action,FilterDispatcher则把请求的处理交给ActionProxy。
5. ActionProxy通过Configuration Manager(struts.xml)询问框架的配置文件,找到需要的Action类。
6. ActionProxy创建一个ActionInvocation实例,同时ActionInvocation通过代理模式调用Action。但在调用之前,ActionInvocation会根据配置加载Action相关的所有Interceptor(拦截器)。
7. 一旦Action执行完毕,ActionInvocation负责根据struts.xml中的配置找到相应的返回结果result。
二、 业务控制器Action
1. 业务控制器Action由开发者自己编写实现,Action类可以是一个简单的Java类,与Servlet API完全分
离。Action一般都有一个execute() 方法,也可以定义其他的业务控制方法。
2. Struts2提供了一个ActionSupport工具类,该类实现了Action接口和validate() 方法,一般开发者编写Action可以直接继承ActionSupport类。
3. 编写Action类后,开发者还必须在配置文件中配置Action。一个Action的配置应该包含以下几个元素:
1. 该Action的name,即用户请求所指向的URL。
2. Action所对应的class元素,对应Action类的位置。
3. 指定result逻辑名称和实际资源的定位。
三、 业务模型组件
业务模型组件可以是实现业务逻辑的模块,可以是EJB、POJO或者JavaBean。