1.4 Struts 2概述
从字面上看,Struts 2好像是Struts 1的升级版本,其实Struts 2更像是WebWork,Apache之所以命名为Struts 2,笔者认为有如下原因:
Struts 1.X是目前应用最早的一种MVC架构,经过了多年的考验,被广大Java开发者所接受,大量的Java Web应用中使用了Struts 1.X,证明了Struts 1出色的稳定性和可用性。Struts 1成为Apache成功的产品之一。
WebWork兴起时间比较短,尽管展示了其更加先进的技术优势,但是被开发者接受需要时间的验证,至少国内目前使用WebWork架构开发案例比较少,更多使用WebWork架构搭建的系统一般都是出于学习和测试的目的。
Apache接手WebWork项目后,有意于借助Struts 1.X在业界的成功来推广Struts 2。Struts 2非常类似于WebWork框架,而不是Struts 1.X框架,是以WebWork为核心来实现的。
从Struts 1.X过渡到Struts 2所改变的东西比较多,但是只要领会了MVC设计思想和Java Web开发的理念,读者会发现,Struts 2将比Struts 1.X更加简单,更加灵活。如果读者熟悉WebWork框架,那么学习Struts 2是一件比较容易的事情。
1.4.1 Struts 2框架
Struts 2相对于Struts 1.X,将实现用户业务逻辑(Action)同Servlet API分离开,这种分离机制,是采用了拦截器或者拦截器栈(拦截器链)。拦截器是Struts 2的核心内容之一。
Struts 2内建了多个拦截器和拦截器栈(由多个拦截器形成的拦截器链),将用户的Web请求进行拦截处理,从而提供了更加丰富的功能,例如数据类型转换、国际化、文件上传等。图1.9所示是Struts 2框架结构图,Struts 2框架中的处理大概分为以下几个步骤:
客户端初始化一个指向Servlet容器(例如Tomcat)的请求。
这个请求经过一系列的过滤器(Filter)(这些过滤器中有一个叫做ActionContextCleanUp的可选过滤器,这个过滤器对于Struts 2和其他框架的集成很有帮助,例如SiteMesh Plugin)。
接着FilterDispatcher被调用,FilterDispatcher询问ActionMapper来决定这个请求是否需要调用某个Action。
如果ActionMapper决定需要调用某个Action,FilterDispatcher把请求的处理交给ActionProxy。
ActionProxy通过Configuration Manager询问框架的配置文件,找到需要调用的Action类。
ActionProxy创建一个ActionInvocation实例。
ActionInvocation实例使用命名模式来调用,回调Action的execute方法,该execute方法先获取用户请求参数,然后它会调用业务逻辑组件来处理用户的请求。在调用Action的过程前后,涉及到相关拦截器(Interceptor)的调用。
一旦Action执行完毕,ActionInvocation负责根据struts.xml中的配置找到对应的返回结果。返回结果通常是(但不总是,也可能是另外的一个Action链)一个需要被表示的JSP或者FreeMarker的模板。在表示的过程中可以使用Struts 2框架中继承的标签。
由于印刷原因,读者不能够根据图上的不同颜色来区分结构。下面使用文字进行介绍。
Servlet Filter:包括ActionContextCleanUp、Other Filters和FilterDispatcher。
Struts Core:Struts核心模块,包含ActionMapper、标签库、ActionProxy、ActionInvocation、Result。
拦截器(Interceptor)。
用户创建代码:这部分包含struts.xml、Action、视图(JSP等)。
从上面的描述读者可以看到,实现一个Struts应用,只需要配置struts.xml文件、编写Action代码和相关视图资源文件即可。图1.10所示是Struts 2架构图,从图中可以看到,从用户请求到Action执行,过程中间布满了拦截器,这些拦截器可以在Action执行之前或者执行之后来运行。拦截器是Struts 2核心内容之一,后面将会详细介绍。
★ 说明 ★
Struts 2框架流程图和WebWork框架流程图相互比较,读者会发现两者极其相似,进一步说明了Struts 2框架是WebWork的升级版本。、
图1.10 Struts 2架构图
1.4.2 Struts 2配置文件
Struts 2配置文件是用户请求(View)和业务逻辑模块(Model)Action之间联系的桥梁,开发者可以通过修改Struts 2的配置文件,来快速适应业务需求,它是整个Struts 2的精髓之一。当然,熟悉Struts 1和WebWork框架的读者对配置文件一定不会陌生。Struts 2框架配置文件一般可以分为两类:struts.xml文件和属性资源文件。
1.配置Action的struts.xml文件
配置Action的struts.xml文件,也包括用户自己定义的*.xml文件,然后通过include指令包含到struts.xml文件中。struts.xml文件包含了Action的定义,同时定义了Action返回值对应的视图资源(result),还有命名空间信息等。
★ 说明 ★
struts.xml文件是Struts 2框架的核心配置文件,开发者可以建立独立的配置文件,在struts.xml中使用include指令包含进来,后面章节将会做详细介绍。
(1)代码1.5就是一个struts.xml的例子。
代码1.5 配置文件struts.xml示例
<! DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd" >
< struts >
<!-- 开始Struts 2配置 -->
<!-- 配置Struts 2的pachage,Action必须配置在其中 -->
< package name ="pla" extends ="struts-default" >
<!-- 配置Action -->
< action name ="login" class ="pla.LoginAction" >
<!-- 配置Action的返回值success视图 -->
< result name ="success" > /welcome.jsp </ result >
<!-- 配置Action的返回值error视图 -->
< result name ="error" > / error.jsp </ result >
<!-- 配置Action的返回值input视图 -->
< result name ="input" > / input.jsp </ result >
</ action >
</ package >
</ struts >
上面配置文件struts.xml中定义了一个Action:
<action name="login" class="pla.LoginAction">