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:
Result, ReflectionExceptionHandler, Serializable, StrutsStatics

public class ServletActionRedirectResult
extends ServletRedirectResult
implements ReflectionExceptionHandler

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. 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="redirectAction">
             <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="redirectAction">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 redirectAction url generated will be :
    /genReport/generateReport.action?reportType=pie&width=100&height=100#summary
    -->
    <action name="gatherReportInfo" class="...">
       <result name="showReportResult" type="redirectAction">
          <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>
          <param name="empty"></param>
          <param name="suppressEmptyParameters">true</param>
          <param name="anchor">summary</param>
       </result>
    </action>
 </package>


 
 

See Also:
ActionMapper, Serialized Form

Field Summary
protected  String actionName
           
static String DEFAULT_PARAM
           
protected  String method
           
protected  String namespace
           
 
Fields inherited from class org.apache.struts2.dispatcher.ServletRedirectResult
actionMapper, anchor, prependServletContext, requestParameters, statusCode, suppressEmptyParameters
 
Fields inherited from interface org.apache.struts2.StrutsStatics
HTTP_REQUEST, HTTP_RESPONSE, PAGE_CONTEXT, SERVLET_CONTEXT, SERVLET_DISPATCHER, STRUTS_ACTION_TAG_INVOCATION, STRUTS_PORTLET_CONTEXT
 
Constructor Summary
ServletActionRedirectResult()
           
ServletActionRedirectResult(String actionName)
           
ServletActionRedirectResult(String actionName, String method)
           
ServletActionRedirectResult(String namespace, String actionName, String method)
           
ServletActionRedirectResult(String namespace, String actionName, String method, String anchor)
           
 
Method Summary
 void execute(ActionInvocation invocation)
          Implementation of the execute method from the Result interface.
protected  List<String> getProhibitedResultParams()
           
 void setActionName(String actionName)
          Sets the action name
 void setMethod(String method)
          Sets the method
 void setNamespace(String namespace)
          Sets the namespace
 
Methods inherited from class org.apache.struts2.dispatcher.ServletRedirectResult
addParameter, doExecute, handle, sendRedirect, setActionMapper, setAnchor, setPrependServletContext, setStatusCode, setSuppressEmptyParameters, setUrlHelper
 
Methods inherited from class org.apache.struts2.dispatcher.StrutsResultSupport
conditionalParse, getLastFinalLocation, getLocation, setEncode, setLocation, setParse
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface com.opensymphony.xwork2.util.reflection.ReflectionExceptionHandler
handle
 

Field Detail

DEFAULT_PARAM

public static final String DEFAULT_PARAM
See Also:
Constant Field Values

actionName

protected String actionName

namespace

protected String namespace

method

protected String method
Constructor Detail

ServletActionRedirectResult

public ServletActionRedirectResult()

ServletActionRedirectResult

public ServletActionRedirectResult(String actionName)

ServletActionRedirectResult

public ServletActionRedirectResult(String actionName,
                                   String method)

ServletActionRedirectResult

public ServletActionRedirectResult(String namespace,
                                   String actionName,
                                   String method)

ServletActionRedirectResult

public ServletActionRedirectResult(String namespace,
                                   String actionName,
                                   String method,
                                   String anchor)
Method Detail

execute

public void execute(ActionInvocation invocation)
             throws 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 Result
Overrides:
execute in class ServletRedirectResult
Parameters:
invocation - the execution state of the action.
Throws:
Exception - if an error occurs while executing the result.
See Also:
Result.execute(com.opensymphony.xwork2.ActionInvocation)

setActionName

public void setActionName(String actionName)
Sets the action name

Parameters:
actionName - The name

setNamespace

public void setNamespace(String namespace)
Sets the namespace

Parameters:
namespace - The namespace

setMethod

public void setMethod(String method)
Sets the method

Parameters:
method - The method

getProhibitedResultParams

protected List<String> getProhibitedResultParams()
Overrides:
getProhibitedResultParams in class ServletRedirectResult


Copyright © 2000-2012 Apache Software Foundation. All Rights Reserved.