Class EventActionDispatcher
- All Implemented Interfaces:
 Serializable,Dispatcher
An Action helper class that dispatches to to one of the public methods
 that are named in the parameter attribute of the corresponding
 ActionMapping and matches a submission parameter. This is useful for
 developers who prefer to use many submit buttons, images, or submit links
 on a single form and whose related actions exist in a single Action class.
The method(s) in the associated Action must have the same
 signature (other than method name) of the standard Action.execute method.
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="save,back,recalc=recalculate,default=save"/>
 
 where parameter contains three possible methods and one
 default method if nothing matches (such as the user pressing the enter key).
For utility purposes, you can use the key=value notation to
 alias methods so that they are exposed as different form element names, in the
 event of a naming conflict or otherwise. In this example, the recalc
 button (via a request parameter) will invoke the recalculate
 method. The security-minded person may find this feature valuable to
 obfuscate and not expose the methods.
The default key is purely optional. If this is not specified
 and no parameters match the list of method keys, null is
 returned which means the unspecified method will be invoked.
The order of the parameters are guaranteed to be iterated in the order specified. If multiple buttons were accidently submitted, the first match in the list will be dispatched.
To implement this dispatch behaviour in an Action,
 class create your custom Action as follows, along with the methods you require
 (and optionally "cancelled" and "unspecified" methods):
   public class MyCustomAction extends Action {
       protected ActionDispatcher dispatcher = new EventActionDispatcher(this);
       public ActionForward execute(ActionMapping mapping,
                                    ActionForm form,
                                    HttpServletRequest request,
                                    HttpServletResponse response)
                           throws Exception {
           return dispatcher.execute(mapping, form, request, response);
       }
   }
 
 - Since:
 - Struts 1.2.9
 - See Also:
 
- 
Field Summary
Fields inherited from class org.apache.struts.extras.actions.ActionDispatcher
actionInstance, clazz, DEFAULT_FLAVOR, DISPATCH_FLAVOR, flavor, MAPPING_FLAVOR, messages, methods, types - 
Constructor Summary
ConstructorsConstructorDescriptionEventActionDispatcher(Action action) Constructs a new object for the specified action. - 
Method Summary
Modifier and TypeMethodDescriptionprotected StringgetMethodName(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response, String parameter) Returns the method name, given a parameter's value.protected ActionForwardunspecified(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) Dispatches to the target class'unspecifiedmethod, if present, otherwise throws a ServletException.Methods inherited from class org.apache.struts.extras.actions.ActionDispatcher
cancelled, dispatch, dispatchMethod, dispatchMethod, execute, getMethod, getParameter, isCancelled 
- 
Constructor Details
- 
EventActionDispatcher
Constructs a new object for the specified action.- Parameters:
 action- the action
 
 - 
 - 
Method Details
- 
unspecified
protected ActionForward unspecified(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception Dispatches to the target class'
unspecifiedmethod, if present, otherwise throws a ServletException. Classes utilizingEventActionDispatchershould provide anunspecifiedmethod if they wish to provide behavior different than throwing a ServletException.- Overrides:
 unspecifiedin classActionDispatcher- Parameters:
 mapping- The ActionMapping used to select this instanceform- The optional ActionForm bean for this request (if any)request- The non-HTTP request we are processingresponse- The non-HTTP response we are creating- Returns:
 - The forward to which control should be transferred, or
         
nullif the response has been completed. - Throws:
 Exception- if the application business logic throws an exception.
 - 
getMethodName
protected String getMethodName(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response, String parameter) throws Exception Returns the method name, given a parameter's value.- Overrides:
 getMethodNamein classActionDispatcher- Parameters:
 mapping- The ActionMapping used to select this instanceform- The optional ActionForm bean for this request (if any)request- The HTTP request we are processingresponse- The HTTP response we are creatingparameter- TheActionMappingparameter's name- Returns:
 - The method's name.
 - Throws:
 Exception- if an error occurs.
 
 -