配置ActionStruts2的核心功能是action,对于开发人员来说,使用Struts2主要就是编写action,action类通常都要实现com.opensymphony.xwork2.Action接口,并实现该接口中的execute()方法。
该方法如下:public String execute() throws ExceptionStruts2并不是要求所有编写的action类都要实现Action接口,也可以直接编写一个普通的Java类作为action,只要实现一个返回类型为String的无参的public方法即可:public String xxx()在实际开发中,action类很少直接实现Action接口,通常都是从com.opensymphony.xwork2.ActionSupport类继承,ActionSupport实现了Action接口和其他一些可选的接口,提供了输入验证,错误信息存取,以及国际化的支持,选择从ActionSupport继承,可以简化action的定义。
开发好action之后,好需要对action进行配置,以告诉Struts2框架,针对某个URL的请求应该交由哪个action进行处理。
1.Action映射:action映射是Struts2框架中的基本”工作单元”,action映射就是将一个请求URL(即action的名字)映射到一个action类,当一个请求匹配某个action的名字时,框架就使用这个映射来确定如何处理请求。
action元素的完整属性表例如:<action name="user" class="erAction"><result name="success">/user.jsp</result></action>2. 使用method属性在配置action时,我们可以通过action元素的method属性来指定action调用的方法,所指定的方法,必须遵循与execute方法相同的格式。
在Struts2.xml文件中,我们可以为同一个action类配置不同的别名,并使用method属性。
在Struts.xml文件中为同一个Action类配置不同的别名<!-- 使用method属性 --><package name="methods" namespace="/"extends="struts-default"><!-- 对应着MethodAction里面的execute方法 --><action name="list" class="org.lesson05.MethodAction"><result name="success">/Methods/list.jsp</result></action><!-- 对应着MethodAction里面的add方法 --><action name="add" class="org.lesson05.MethodAction"method="add"><result name="success">/Methods/add.jsp</result> </action><!-- 对应着MethodAction里面的edit方法 --><action name="edit" class="org.lesson05.MethodAction"method="edit"><result name="success">/Methods/edit.jsp</result> </action><!-- 对应着MethodAction里面的delete方法 --><action name="delete"class="org.lesson05.MethodAction"method="delete"><result name="success">/Methods/delete.jsp</result> </action></package>对应的MethodAction类,代码如下:import com.opensymphony.xwork2.ActionSupport;public class MethodAction extends ActionSupport{@Overridepublic String execute() throws Exception{return SUCCESS;}public String add() throws Exception{return SUCCESS;}public String edit() throws Exception{return SUCCESS;}public String delete() throws Exception{return SUCCESS;}}使用action的method属性可以任意指定处理请求的方法(只要该方法和execute方法具有相同的格式),这样就可以在同一个类中完成相关的任务,而不需要去编写不同的Action类。
注意:Struts2在根据action元素的method属性查找方法时有两种途径:1.查找与method属性值完全一致的方法.2.查找doMethod()形式的方法.3.动态方法调用:另外一种无需配置就可以直接调用Action中的非execute方法的方式,是使用Struts2的动态方法调用。
动态方法调用是在action的名字中使用感叹号(!)来标识要调用的方法名,其语法格式为 actionName!methodName.action例如,我们配置了如下的action<action name="user" class="erAction"><result name="success">/Methods/list.jsp</result> </action>当请求/user!delete.action时,就会自动调用UserAction中的delete()方法提示,这种调用方式会带来安全隐患!4.模拟Struts1中的ForwardAction<action name="user"><result>/index.jsp</result></action>这样写就可以了.5.默认的action如果请求一个不存在的action,结果将是HTTP404错误。
在Struts2中,可以指定一个默认的action,如果一个请求没有其他的action匹配,那么默认的action将被执行。
默认的action使用default-action-ref元素来声明,如下所示:<!-- 默认action --><package name="defaultAction" namespace="/default"extends="struts-default"><default-action-ref name="error"></default-action-ref><action name="defaultaction"class="org.lesson05.DefaultAction"><result name="success">/defaultAction.jsp</result> </action><action name="error"><result>/error.jsp</result></action></package>注意:根据struts-2.0.dtd中定义的package元素的内容模型,default-acion-ref必须在action元素之前使用。
如果请求的是/default/defaultaction1.action,框架找不到映射到defaultaction1的action,那么名为error的action将被调用。
注意:每个包中都可以有它自己默认的action,但是每一个名称空间应该只有一个默认action。
如果具有相同名称空间的多个包中都声明了默认action,那么哪一个action才是默认的将无法保证。
注意:默认action只对action的访问有效。
如果你访问一个非action的资源,例如/user.jsp,而该页面不存在,这时仍会看到HTTP404错误。
如果想为整个Web 应用程序指定默认页面,需要在web.xml文件中对HTTP404错误指定相应的错误处理页面。
6.通配符映射随着Web应用程序的增加,所需的Action也会更多,从而导致大量的action映射,使用通配符可以减少action配置的数量,使一些具有类似行为的Action或者Action方法可以使用通用的样式来配置。
通配符即星号(*),用于匹配0个或多个字符,在配置action时,可以在action 元素的name属性中使用星号(*)来匹配任意的字符。
以下是在action映射中使用通配符:<action name="news*"class="org.struts2.lesson05.News{1}Action"><result name="success">/WEB-INF/News/{1}.jsp</result> </action>我们在action元素的name属性中使用了通配符(*),允许这个映射匹配所有以/news开始的URL,例如/newsAdd,/newsEdit,/newsDelete,但是,如果请求的是/newsEdit/add,那么这个映射就不会被匹配。