Struts2中Action创建
在Struts2的应用开发中,Action作为框架的核心类,负责对用户请求的处理,也被称为业务逻辑控制器。一个Action类代表依次请求或调用,每个请求动作都会有一个响应的Action类。
建立一个Action类主要有以下三种方式:
- POJO(Plain Ordinary Java Object) 简单Java对象
- 实现Action接口
- 集成ActionSupport类
POJO
在Struts2中,Action可以不继承特殊的类或不实现任何接口,仅仅是一个POJO,一般来讲,要有一个公共的无参构造方法和一个execute
方法,如下:
public class Hello1Action {
public String execute() {
System.out.println("hello 1 excute");
return "success";
}
}
其中execute
方法要求如下:
- 权限修饰符为public
- 返回一个字符串,指示下一个页面的result
- 无参方法
实现Action接口
为了让开发人员开发的Action类更规范,Struts2提供了一个Action接口,在自定义Action类时可以实现这个接口,如下:
public class Hello2Action implements Action {
@Override
public String execute() throws Exception {
System.out.println("hello 2 action");
return SUCCESS;
}
}
Action接口位于com.opensymphony.xwork2.Action
包中,这里需要实现execute
方法并返回一个字符串。除此之外,该接口还定义了5个字符串常量,用来统一execute
方法的返回值。
- SUCCESS:success,代表成功
- NONE:none,代表页面不跳转
- ERROR:error,跳转到错误页面
- INPUT:input,数据校验时跳转的路径
- LOGIN:login,跳转登录页面
继承ActionSupport类(推荐)
在开发过程中,更推荐的做法是继承ActionSupport类,其中ActionSupport实现了Action接口,除此之外,还实现了Validateable、ValidationAware、TextProvider、LocaleProvider和Seriable等接口,为我们提供了更多的功能,
示例如下:
public class Hello3Action extends ActionSupport {
public String execute(){
System.out.println("hello 3 action");
return SUCCESS;
}
}
ActionSupport类中提供了许多默认方法,包括获取国际化信息、数据校验、默认处理用户请求的方法等,通过继承该类能简化我们Action的开发。
Action的访问
之前说过,通过URL进行访问时通过package
的namespace
和action
的name
属性决定的,然后通过action
中的method
属性指定Action中具体执行哪个方法。
配置Action的访问方式主要有三种:
- 原始方式
- 通配符方式
- 动态方法访问
首先附上UserAction
相关代码:
public class UserAction extends ActionSupport {
public String add() {
System.out.println("add");
return NONE;
}
public String delete() {
System.out.println("delete");
return NONE;
}
public String update() {
System.out.println("update");
return NONE;
}
public String query() {
System.out.println("query");
return NONE;
}
}
原始方式
就是之前介绍到的,配置method
来决定执行Action的哪个方法。
如下:
<package name="user" namespace="/user" extends="struts-default">
<action name="add" class="com.happ.demo.user.UserAction" method="add">
</action>
</package>
通配符方式
考虑一种情况,加入现在UserAction
下分别有增删改查四个方法,按照之前的逻辑需要配置四份Action,如下:
<package name="user" namespace="/user" extends="struts-default">
<action name="add" class="com.happ.demo.user.UserAction" method="add">
</action>
<action name="delete" class="com.happ.demo.user.UserAction" method="delete">
</action>
<action name="update" class="com.happ.demo.user.UserAction" method="update">
</action>
<action name="query" class="com.happ.demo.user.UserAction" method="query">
</action>
</package>
显然,这样就显得过于冗长和复杂,在此,我们可以使用通配符方式解决,如下:
<package name="user" namespace="/user" extends="struts-default">
<action name="user_*" class="com.happ.demo.user.UserAction" method="{1}"/>
</package>
其中,action
中的name
属性使用的*
代表任意字符,method
中的{1}
代表name
属性中出现的第一个*
所代替的字符串。
例如,当请求/user_add.action
时,name属性为user_add
,methon属性就为add
,紧接着就会调用到Action类中的add
方法。
在开发中,通配符方式是使用比较多的。
动态方法访问
动态方法访问在Struts2中默认是关闭的,如果需要使用,先开启一个常量:
<constant name="struts.enable.DynamicMethodInvocation" value="true"/>
动态方法访问主要的控制是在页面端,编写和配置Action比较简单,主要是访问路径的编写。
struts.xml
配置如下:
<constant name="struts.enable.DynamicMethodInvocation" value="true"/>
<package name="user" namespace="/user" extends="struts-default">
<action name="userAction" class="com.happ.demo.user.UserAction"/>
</package>
页面路径写法为:
/user/UserAction!add.action
/user/UserAction!delete.action
/user/UserAction!update.action
/user/UserAction!query.action
这样就完成了Action的动态方法访问。