Struts2注解配置之@Results和@Result

在Struts2注解配置之@Action(二)中对于结果页面我还是采用Convention Plugin的约定,需要利用@Results和@Result改变一下这种约定。以及@Results和@Result对类和方法进行注解后所产生的效果。
代码:
package com.example.actions;

import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.Result;
import org.apache.struts2.convention.annotation.Results;

import com.opensymphony.xwork2.ActionSupport;

@Results( { @Result(name = "global", location = "/global.jsp") })
public class HelloWorld5 extends ActionSupport {

	@Action(value = "/H5/url", results = { @Result(name = SUCCESS, location = "/H5/success.jsp"),
			@Result(name = "failure", location = "/H5/fail.jsp") })
	public String execute() {
		if (System.currentTimeMillis() % 3 == 0) {
			return "failure";
		} else if (System.currentTimeMillis() % 3 == 1) {
			return SUCCESS;
		} else {
			return "global";
		}
	}

	@Action("globalTest")
	public String global() {
		return "global";
	}

	@Action(value = "globalOverWrite", results = { @Result(name = "global", location = "/H5/globalOverWrite.jsp") })
	public String globalOverWrite() {
		return "global";
	}

}

    使用@Result注解改变Convention Plugin的约定跳转页面。 

在代码的String execute()方法上进行了    @Action(value = "/H5/url", results = { @Result(name = SUCCESS, location = "/H5/success.jsp"),
            @Result(name = "failure", location = "/H5/fail.jsp") })注解。如果@Action(...)没有results = { @Result(name = SUCCESS, location = "/H5/success.jsp"),
            @Result(name = "failure", location = "/H5/fail.jsp") },那么依据Convention Plugin的约定,结果页面会是/H5/url.jsp。加上红色字体的部分后,execute()方法执行后,会根据红色字体的配置,将结果跳转到对应的页面。

    对Action类添加@Result注解,@Result将被Action类中的所有方法所共享。

仔细观察上述代码,在HelloWorld5上进行了@Results( { @Result(name = "global", location = "/global.jsp") })注解。这意味着该类及其子类的所有方法都可以返回一个名字为“global”的结果页面。而这个页面是"/global.jsp"。这就使得不用在每个需要跳转到"/global.jsp"的方法都进行@Result(name = "global", location = "/global.jsp")注解。这在实际工作中也是非常常见的一种情况。可以仔细观察的execute()方法和global()方法。他们都可能跳转到名字为“global”的结果页面(即location属性定义的“/global.jsp”页面)。

    对Action类中的方法添加@Result注解,@Result将只作用于被添加的方法。Action类方法上添加的@Result优先级高于Action类上添加的@Result。(前者覆盖后者)

再仔细观察上述代码的globalOverWrite()方法,该方法也跳转到名字为“global”的页面。但是在该方法上使用了@Action(value = "globalOverWrite", results = { @Result(name = "global", location = "/H5/globalOverWrite.jsp") })注解。并且其中@Result(...)注解中也有一个名字为“global”的结果页面定义。此时,该方法的结果页面就会跳转到/H5/globalOverWrite.jsp页面而不是在类上进行注解时候的“/global.jsp”页面。


你可能感兴趣的:(Struts2注解配置之@Results和@Result)