006--Struts2中Action创建及访问方式

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进行访问时通过packagenamespaceactionname属性决定的,然后通过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的动态方法访问。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值