org.apache.struts2.dispatcher.mapper
Class Restful2ActionMapper
java.lang.Object
org.apache.struts2.dispatcher.mapper.DefaultActionMapper
org.apache.struts2.dispatcher.mapper.Restful2ActionMapper
- All Implemented Interfaces:
- ActionMapper
public class Restful2ActionMapper
- extends DefaultActionMapper
Improved restful action mapper that adds several ReST-style improvements to
action mapping, but supports fully-customized URL's via XML. The two primary
ReST enhancements are:
- If the method is not specified (via '!' or 'method:' prefix), the method is
"guessed" at using ReST-style conventions that examine the URL and the HTTP
method.
- Parameters are extracted from the action name, if parameter name/value pairs
are specified using PARAM_NAME/PARAM_VALUE syntax.
These two improvements allow a GET request for 'category/action/movie/Thrillers' to
be mapped to the action name 'movie' with an id of 'Thrillers' with an extra parameter
named 'category' with a value of 'action'. A single action mapping can then handle
all CRUD operations using wildcards, e.g.
<action name="movie/*" className="app.MovieAction">
<param name="id">{0}</param>
...
</action>
This mapper supports the following parameters:
struts.mapper.idParameterName
- If set, this value will be the name
of the parameter under which the id is stored. The id will then be removed
from the action name. This allows restful actions to not require wildcards.
The following URL's will invoke its methods:
GET: /movie/ => method="index"
GET: /movie/Thrillers => method="view", id="Thrillers"
GET: /movie/Thrillers!edit => method="edit", id="Thrillers"
GET: /movie/new => method="editNew"
POST: /movie/ => method="create"
PUT: /movie/Thrillers => method="update", id="Thrillers"
DELETE: /movie/Thrillers => method="remove", id="Thrillers"
To simulate the HTTP methods PUT and DELETE, since they aren't supported by HTML,
the HTTP parameter "__http_method" will be used.
The syntax and design for this feature was inspired by the ReST support in Ruby on Rails.
See
http://ryandaigle.com/articles/2006/08/01/whats-new-in-edge-rails-simply-restful-support-and-how-to-use-it
Methods inherited from class org.apache.struts2.dispatcher.mapper.DefaultActionMapper |
addParameterAction, dropExtension, dropExtension, getDefaultExtension, getMappingFromActionName, getUri, getUriFromActionMapping, handleSpecialParameters, isSlashesInActionNames, parseActionName, parseNameAndNamespace, setAllowDynamicMethodCalls, setAlwaysSelectFullNamespace, setContainer, setExtensions, setSlashesInActionNames |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
LOG
protected static final Logger LOG
HTTP_METHOD_PARAM
public static final String HTTP_METHOD_PARAM
- See Also:
- Constant Field Values
idParameterName
private String idParameterName
Restful2ActionMapper
public Restful2ActionMapper()
getMapping
public ActionMapping getMapping(HttpServletRequest request,
ConfigurationManager configManager)
- Description copied from interface:
ActionMapper
- Expose the ActionMapping for the current request
- Specified by:
getMapping
in interface ActionMapper
- Overrides:
getMapping
in class DefaultActionMapper
- Parameters:
request
- The servlet requestconfigManager
- The current configuration manager
- Returns:
- The appropriate action mapping
isGet
protected boolean isGet(HttpServletRequest request)
isPost
protected boolean isPost(HttpServletRequest request)
isPut
protected boolean isPut(HttpServletRequest request)
isDelete
protected boolean isDelete(HttpServletRequest request)
getIdParameterName
public String getIdParameterName()
setIdParameterName
public void setIdParameterName(String idParameterName)
Copyright © 2000-2008 Apache Software Foundation. All Rights Reserved.