Action的编写方式:
1、POJO对象
public class RequestAction { public String execute() { return "success"; } }
2、实现Action接口
public class RequestAction2 implements Action { @Override public String execute() throws Exception { return SUCCESS; } }
接口中定义了5种逻辑视图名称
public static final String SUCCESS = "success"; // 数据处理成功 (成功页面)
public static final String NONE = "none"; // 页面不跳转 return null; 效果一样
public static final String ERROR = "error"; // 数据处理发送错误 (错误页面)
public static final String INPUT = "input"; // 用户输入数据有误,通常用于表单数据校验 (输入页面)
public static final String LOGIN = "login"; // 主要权限认证 (登陆页面)
3、继承ActionSupport类
public class RequestAction3 extends ActionSupport { @Override public String execute() throws Exception { return SUCCESS; } }
这种方式更为常用,ActionSupport实现了表单校验、错误信息设置、读取国际化信息 三个功能
public class ActionSupport implements Action, Validateable, ValidationAware, TextProvider, LocaleProvider, Serializable {}
Action中的方法调用
1、通过mehtod属性配置
链接
<a href="${pageContext.request.contextPath }/demo03/regist.action">注册</a>
编写Action类,采用继承ActionSupport这种方式
public class RegistAction extends ActionSupport { @Override public String execute() throws Exception { System.out.println("RegistAction--execute()"); return NONE; } public String regist() { System.out.println("RegistAction--regist()"); return NONE; } }
struts配置
<package name="demo03" namespace="/demo03" extends="struts-default"> <action name="regist" class="demo03.RegistAction" method="regist"> </action> </package>如果不配置method属性,将默认执行execute方法,如果配置就执行regist方法,通过这种方式可以将多个业务方法封装到一个Action中,但配置文件并没有减少,要在struts.xml中配置多个<action>
2、使用通配符
链接
<a href="${pageContext.request.contextPath }/demo03/customer_add.action">新增</a> <a href="${pageContext.request.contextPath }/demo03/customer_upd.action">修改</a> <a href="${pageContext.request.contextPath }/demo03/customer_del.action">删除</a>
action类
public class CustomerAction extends ActionSupport { public String add() throws Exception { System.out.println("CustomerAction--add()"); return NONE; } public String upd() throws Exception { System.out.println("CustomerAction--upd()"); return NONE; } public String del() throws Exception { System.out.println("CustomerAction--del()"); return NONE; } }
配置
<package name="demo03" namespace="/demo03" extends="struts-default"> <action name="customer_*" class="demo03.CustomerAction" method="{1}"> </action> </package>
通过customer_*这种方式简化配置,在method中使用{数字}来调用action中的方法,这是action的命名就必须规范
使用两个通配符
//jsp <a href="${pageContext.request.contextPath }/demo03/AAAAction_add.action">删除</a> //action public class AAAAction extends ActionSupport { public String add() { return NONE; } } //struts配置 <action name="*Action_*" class="demo03.{1}Action" method="{2}"> </action>
3、动态方法调用
在struts.xml配置常量,开启动态方法调用
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
页面链接,使用"!方法名称"的方式调用action中方法
<a href="${pageContext.request.contextPath }/demo03/customer!add.action">新增</a> <a href="${pageContext.request.contextPath }/demo03/customer!upd.action">修改</a> <a href="${pageContext.request.contextPath }/demo03/customer!del.action">删除</a>
action类
public class ProductAction extends ActionSupport { public String add() throws Exception { System.out.println("CustomerAction--add()"); return NONE; } public String upd() throws Exception { System.out.println("CustomerAction--upd()"); return NONE; } public String del() throws Exception { System.out.println("CustomerAction--del()"); return NONE; } }
配置,不用配置method,也不用通配符,这种方式结合注解,struts可以近乎于零配置
<action name="product" class="demo03.ProductAction">