java.lang.Objectorg.apache.struts.action.Action
org.apache.struts.actions.DispatchAction
org.apache.struts.actions.MappingDispatchAction
An abstract Action that dispatches to a public
method that is named by the parameter
attribute of
the corresponding ActionMapping. This is useful for developers who prefer
to combine many related actions into a single Action class.
To configure the use of this action in your
struts-config.xml
file, create an entry like this:
<action path="/saveSubscription"
type="org.example.SubscriptionAction"
name="subscriptionForm"
scope="request"
input="/subscription.jsp"
parameter="method"/>
where 'method' is the name of a method in your subclass of MappingDispatchAction that has the same signature (other than method name) of the standard Action.execute method. For example, you might combine the methods for managing a subscription into a single MappingDispatchAction class using the following methods:
for which you would create corresponding <action> configurations that reference this class:
<action path="/createSubscription"
type="org.example.SubscriptionAction"
parameter="create">
<forward name="success" path="/editSubscription.jsp"/>
</action>
<action path="/editSubscription"
type="org.example.SubscriptionAction"
parameter="edit">
<forward name="success" path="/editSubscription.jsp"/>
</action>
<action path="/saveSubscription"
type="org.example.SubscriptionAction"
parameter="save"
name="subscriptionForm"
validate="true"
input="/editSubscription.jsp"
scope="request">
<forward name="success" path="/savedSubscription.jsp"/>
</action>
<action path="/deleteSubscription"
type="org.example.SubscriptionAction"
name="subscriptionForm"
scope="request"
input="/subscription.jsp"
parameter="delete">
<forward name="success" path="/deletedSubscription.jsp"/>
</action>
<action path="/listSubscriptions"
type="org.example.SubscriptionAction"
parameter="list">
<forward name="success" path="/subscriptionList.jsp"/>
</action>
NOTE - Unlike DispatchAction, mapping characteristics may differ between the various handlers, so you can combine actions in the same class that, for example, differ in their use of forms or validation. Also, a request parameter, which would be visible to the application user, is not required to enable selection of the handler method.
$
- Rev: 54929 $ $Date: 2004-10-16 17:38:42 +0100 (Sat, 16 Oct 2004) $Struts
- 1.2Fields inherited from org.apache.struts.actions.DispatchAction: |
---|
clazz, log, messages, methods, types |
Method from org.apache.struts.actions.MappingDispatchAction Summary: |
---|
execute, getMethodName, unspecified |
Methods from org.apache.struts.actions.DispatchAction: |
---|
cancelled, dispatchMethod, execute, getMethod, getMethodName, getParameter, unspecified |
Methods from java.lang.Object: |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Method from org.apache.struts.actions.MappingDispatchAction Detail: |
---|
ActionForward instance describing where and how
control should be forwarded, or null if the response has
already been completed.
This method dispatches the request to other methods of
MappingDispatchAction using the 'parameter' attribute of
ActionMapping and Java Introspection. |
|
MappingDispatchAction should override this method
if they wish to provide default behavior different than throwing a
ServletException. |