org.apache.struts2.dispatcher
Class ServletActionRedirectResult
java.lang.Object
org.apache.struts2.dispatcher.StrutsResultSupport
org.apache.struts2.dispatcher.ServletRedirectResult
org.apache.struts2.dispatcher.ServletActionRedirectResult
- All Implemented Interfaces:
- com.opensymphony.xwork2.Result, java.io.Serializable, StrutsStatics
public class ServletActionRedirectResult
- extends ServletRedirectResult
This result uses the ActionMapper
provided by the ActionMapperFactory
to redirect the browser to a
URL that invokes the specified action and (optional) namespace. This is better than the ServletRedirectResult
because it does not require you to encode the URL patterns processed by the ActionMapper
in to your struts.xml
configuration files. This means you can change your URL patterns at any point and your application will still work.
It is strongly recommended that if you are redirecting to another action, you use this result rather than the
standard redirect result.
To pass parameters, the <param> ... </param> tag. The following parameters will not be
passable becuase they are part of the config param for this particular result.
- actionName
- namespace
- method
- encode
- parse
- location
- prependServletContext
See examples below for an example of how request parameters could be passed in.
This result type takes the following parameters:
- actionName (default) - the name of the action that will be redirect to
- namespace - used to determine which namespace the action is in that we're redirecting to . If namespace is
null, this defaults to the current namespace
Example:
<package name="public" extends="struts-default">
<action name="login" class="...">
<!-- Redirect to another namespace -->
<result type="redirect-action">
<param name="actionName">dashboard</param>
<param name="namespace">/secure</param>
</result>
</action>
</package>
<package name="secure" extends="struts-default" namespace="/secure">
<-- Redirect to an action in the same namespace -->
<action name="dashboard" class="...">
<result>dashboard.jsp</result>
<result name="error" type="redirect-action>error</result>
</action>
<action name="error" class="...">
<result>error.jsp</result>
</action>
</package>
<package name="passingRequestParameters" extends="struts-default" namespace="/passingRequestParameters">
<-- Pass parameters (reportType, width and height) -->
<!--
The redirect-action url generated will be :
/genReport/generateReport.action?reportType=pie&width=100&height=100
-->
<action name="gatherReportInfo" class="...">
<result name="showReportResult" type="redirect-action">
<param name="actionName">generateReport</param>
<param name="namespace=">/genReport</param>
<param name="reportType">pie</param>
<param name="width">100</param>
<param name="height">100</param>
</result>
</action>
</package>
- See Also:
ActionMapper
,
Serialized Form
Method Summary |
void |
execute(com.opensymphony.xwork2.ActionInvocation invocation)
Implementation of the execute method from the Result interface. |
void |
setActionName(java.lang.String actionName)
Sets the action name |
void |
setMethod(java.lang.String method)
Sets the method |
void |
setNamespace(java.lang.String namespace)
Sets the namespace |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
DEFAULT_PARAM
public static final java.lang.String DEFAULT_PARAM
- The default parameter
- See Also:
- Constant Field Values
actionName
protected java.lang.String actionName
namespace
protected java.lang.String namespace
method
protected java.lang.String method
prohibitedResultParam
protected java.util.List<java.lang.String> prohibitedResultParam
ServletActionRedirectResult
public ServletActionRedirectResult()
execute
public void execute(com.opensymphony.xwork2.ActionInvocation invocation)
throws java.lang.Exception
- Description copied from class:
StrutsResultSupport
- Implementation of the execute method from the Result interface. This will call
the abstract method
StrutsResultSupport.doExecute(String, ActionInvocation)
after optionally evaluating the
location as an OGNL evaluation.
- Specified by:
execute
in interface com.opensymphony.xwork2.Result
- Overrides:
execute
in class StrutsResultSupport
- Parameters:
invocation
- the execution state of the action.
- Throws:
java.lang.Exception
- if an error occurs while executing the result.- See Also:
Result.execute(com.opensymphony.xwork2.ActionInvocation)
setActionName
public void setActionName(java.lang.String actionName)
- Sets the action name
- Parameters:
actionName
- The name
setNamespace
public void setNamespace(java.lang.String namespace)
- Sets the namespace
- Parameters:
namespace
- The namespace
setMethod
public void setMethod(java.lang.String method)
- Sets the method
- Parameters:
method
- The method
Copyright © 2000-2006 Apache Software Foundation. All Rights Reserved.