@Target(value={METHOD,TYPE}) @Retention(value=RUNTIME) public @interface Action
This annotation can be used to control the URL that maps to a specific method in an Action class. By default, the method that is invoked is the execute method of the action and the URL is based on the package and class names. This annotation allows developers to change the URL or invoke a different method. This also allows developers to specify multiple URLs that will be handled by a single class or a single method.
 This can also be used via the Actions annotation
 to associate multiple URLs with a single method.
 
Here's an example:
 public class MyAction implements Action {
    @Action("/foo/bar")
   public String execute() {}
 }
 
 | Modifier and Type | Fields and Description | 
|---|---|
| static String | DEFAULT_VALUE | 
| Modifier and Type | Optional Element and Description | 
|---|---|
| String | classNameAllows actions to specify different class name. | 
| ExceptionMapping[] | exceptionMappings | 
| InterceptorRef[] | interceptorRefsAllows action methods to specify what interceptors must be applied to it. | 
| String[] | params | 
| Result[] | resultsAllows action methods to specifically control the results for specific return values. | 
| String | valueAllows actions to specify different URLs rather than the default that is based on the package
 and action name. | 
public static final String DEFAULT_VALUE
public abstract String value
public abstract Result[] results
public abstract InterceptorRef[] interceptorRefs
public abstract String[] params
{"key", "value", "key2", "value2"}.public abstract ExceptionMapping[] exceptionMappings
public abstract String className
Copyright © 2000–2025 Apache Software Foundation. All rights reserved.