org.apache.struts2.dispatcher
Class ServletActionRedirectResult

java.lang.Object
  extended by org.apache.struts2.dispatcher.StrutsResultSupport
      extended by org.apache.struts2.dispatcher.ServletRedirectResult
          extended by 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.

See examples below for an example of how request parameters could be passed in. This result type takes the following parameters: 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

Field Summary
protected  java.lang.String actionName
           
static java.lang.String DEFAULT_PARAM
          The default parameter
protected  java.lang.String method
           
protected  java.lang.String namespace
           
protected  java.util.List<java.lang.String> prohibitedResultParam
           
 
Fields inherited from class org.apache.struts2.dispatcher.ServletRedirectResult
prependServletContext
 
Fields inherited from class org.apache.struts2.dispatcher.StrutsResultSupport
encode, location, parse
 
Fields inherited from interface org.apache.struts2.StrutsStatics
HTTP_REQUEST, HTTP_RESPONSE, PAGE_CONTEXT, SERVLET_CONTEXT, SERVLET_DISPATCHER, STRUTS_PORTLET_CONTEXT
 
Constructor Summary
ServletActionRedirectResult()
           
 
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 org.apache.struts2.dispatcher.ServletRedirectResult
doExecute, setPrependServletContext
 
Methods inherited from class org.apache.struts2.dispatcher.StrutsResultSupport
conditionalParse, setEncode, setLocation, setParse
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

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
Constructor Detail

ServletActionRedirectResult

public ServletActionRedirectResult()
Method Detail

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.