概况
Result类型 是在Action执行完,一个结果返回后决定发生什么事的类。开发者可以自由的根据他们的应用和环境的需要创建自己的Result类型。例如在WebWork2中,Servlet和Velocity结果类型已经被创建用来显示web应用程序的画面。
注意: 所有的webwork内建的Result类型都实现了com.opensymphony.xwork.Result接口. 这个接口是所有action执行结果的通用接口,不管这个结果是用来显示一个网页还是产生一个email,发送一个JMS消息,等.
Result类型配置中定义了一些类,把它们映射为action配置中可以引用的名字. 也就是为这些类创建便于记忆的键-值对.
...
<result-types>
<result-type name="dispatcher" class="com.opensymphony.webwork.dispatcher.ServletDispatcherResult" default="true"/>
<result-type name="redirect" class="com.opensymphony.webwork.dispatcher.ServletRedirectResult"/>
<result-type name="velocity" class="com.opensymphony.webwork.dispatcher.VelocityResult"/>
<result-type name="chain" class="com.opensymphony.xwork.ActionChainResult"/>
<result-type name="xslt" class="com.opensymphony.webwork.views.xslt.XSLTResult"/>
<result-type name="jasper" class="com.opensymphony.webwork.views.jasperreports.JasperReportsResult"/>
<result-type name="freemarker" class="com.opensymphony.webwork.views.freemarker.FreemarkerResult"/>
<result-type name="httpheader" class="com.opensymphony.webwork.dispatcher.HttpHeaderResult"/>
<result-type name="stream" class="com.opensymphony.webwork.dispatcher.StreamResult"/>
<result-type name="plaintext" class="com.opensymphony.webwork.dispatcher.PlainTextResult" /> </result-types> ...
<include file="webwork-default.xml"/>
<package name="myPackage" extends="default">
<action name="bar" class="myPackage.barAction">
<!-- default result type is "dispatcher" -->
<!-- default result name is "success" -->
<result>foo.jsp</result>
<result name="error">error.jsp</result>
</result>
</action>
</package>
Result类型
Webwork提供了一些com.opensymphony.xwork.Result接口的实现来使你的action可以容易的用户交互.这些Result类型包括:
- Chain Result - 用于 Action Chaining
- Dispatcher Result - 用于 JSP 整合
- FreeMarker Result - 用于 FreeMarker 整合
- HttpHeader Result - 用于控制特殊的HTTP行为
- JasperReports Result - 用于 JasperReports 整合
- Redirect Result - 用于直接跳转到例外的URL
- Redirect Action Result - 用于直接跳转到另外的action
- Stream Result - 用于向浏览器返回一个InputStream (一般用于文件下载)
- Velocity Result - 用于 Velocity 整合
- XSL Result - 用于 XML/XSLT 整合
- PlainText Result - 用于显示某个页面的原始的文本 (例如 jsp, html 等)
以上摘自 http://wiki.javascud.org/display/ww2cndoc/Result+Types
我们可能有时候需要实现这个功能,比如在访问某个页面的时候需要登录,用户没有登录的时候跳到登录页面,当用户登录之后希望能跳转到用户之前点击的页面。
具体说就是在执行某个Action之后,根据request中的参数来决定跳转的页面。
即:http://xx.com/xx.action?url=www.google.com. 在访问了这个action之后,自动跳转到 www.google.com
实现代码:
1.实现自定义的返回类型
import com.opensymphony.webwork.ServletActionContext;
import com.opensymphony.webwork.dispatcher.WebWorkResultSupport;
import com.opensymphony.xwork.ActionContext;
import com.opensymphony.xwork.ActionInvocation;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class GoUrl extends WebWorkResultSupport ... {
protected void doExecute(String finalLocation, ActionInvocation invocation)
throws Exception ...{
ActionContext ctx = invocation.getInvocationContext();
HttpServletRequest request = (HttpServletRequest) ctx.get(ServletActionContext.HTTP_REQUEST);
HttpServletResponse response = (HttpServletResponse) ctx.get(ServletActionContext.HTTP_RESPONSE);
String url= request.getParameter(finalLocation);
response.sendRedirect(url);
}
}
2.xwork.xml片段
<!-- 自定义返回类型,需要放在拦截器之前 -->
< result - types >
< result - type name = " go-url " class = " com.hallywang.GoUrl " />
</ result - types >
<!-- 自定义拦截器 -->
< interceptors >
< interceptor name = " isLogin " class = " com.hallywang.interceptors.LogInterceptor " />
</ interceptors >
< action name = " login "
class = " login " >
< result name = " go-url " type = " go-url " > url </ result >
< interceptor - ref name = " params " />
< interceptor - ref name = " model-driven " />
< interceptor - ref name = " validationWorkflowStack " />
</ action >
.......
.......
3.login action 的java类
import com.opensymphony.xwork.ActionSupport;
public class LoginAction extends ActionSupport ... {
public String execute() throws Exception ...{
return "go-url";
}
}