| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.springframework.context.support.ApplicationObjectSupport
org.springframework.web.context.support.WebApplicationObjectSupport
org.springframework.web.servlet.support.WebContentGenerator
org.springframework.web.servlet.mvc.AbstractController
org.springframework.web.servlet.mvc.BaseCommandController
public abstract class BaseCommandController
Controller implementation which creates an object (the command object) on receipt of a request and attempts to populate this object with request parameters.
This controller is the base for all controllers wishing to populate
 JavaBeans based on request parameters, validate the content of such
 JavaBeans using Validators
 and use custom editors (in the form of
 PropertyEditors) to transform 
 objects into strings and vice versa, for example. Three notions are mentioned here:
Command class:
 An instance of the command class will be created for each request and populated
 with request parameters. A command class can basically be any Java class; the only
 requirement is a no-arg constructor. The command class should preferably be a
 JavaBean in order to be able to populate bean properties with request parameters.
Populating using request parameters and PropertyEditors:
 Upon receiving a request, any BaseCommandController will attempt to fill the
 command object using the request parameters. This is done using the typical
 and well-known JavaBeans property notation. When a request parameter named
 'firstName' exists, the framework will attempt to call 
 setFirstName([value]) passing the value of the parameter. Nested properties
 are of course supported. For instance a parameter named 'address.city'
 will result in a getAddress().setCity([value]) call on the
 command class.
It's important to realise that you are not limited to String arguments in
 your JavaBeans. Using the PropertyEditor-notion as supplied by the
 java.beans package, you will be able to transform Strings to Objects and
 the other way around. For instance setLocale(Locale loc) is
 perfectly possible for a request parameter named locale having
 a value of en, as long as you register the appropriate
 PropertyEditor in the Controller (see initBinder()
 for more information on that matter.
Validators:
 After the controller has successfully populated the command object with
 parameters from the request, it will use any configured validators to
 validate the object. Validation results will be put in a
 Errors object which can be
 used in a View to render any input problems.
Workflow
 (and that defined by superclass):
 Since this class is an abstract base class for more specific implementation,
 it does not override the handleRequestInternal() method and also has no
 actual workflow. Implementing classes like
 AbstractFormController,
 AbstractcommandController,
 SimpleFormController and
 AbstractWizardFormController
 provide actual functionality and workflow.
 More information on workflow performed by superclasses can be found
 here.
Exposed configuration properties
 (and those defined by superclass):
 
| name | default | description | 
| commandName | command | the name to use when binding the instantiated command class to the request | 
| commandClass | null | the class to use upon receiving a request and which to fill using the request parameters. What object is used and whether or not it should be created is defined by extending classes and their configuration properties and methods. | 
| validator | null | Validator bean (usually passed in using a <ref bean="beanId"/> property. The validator will be called at appropriate places in the workflow of subclasses (have a look at those for more info) to validate the command object. | 
| validateOnBinding | true | Indicates whether or not to validate the command object after the object has been populated with request parameters. | 
| Field Summary | |
|---|---|
| static String | DEFAULT_COMMAND_NAME | 
| Fields inherited from class org.springframework.web.servlet.support.WebContentGenerator | 
|---|
| HEADER_CACHE_CONTROL, HEADER_EXPIRES, HEADER_PRAGMA, METHOD_GET, METHOD_HEAD, METHOD_POST | 
| Fields inherited from class org.springframework.context.support.ApplicationObjectSupport | 
|---|
| logger | 
| Constructor Summary | |
|---|---|
| BaseCommandController() | |
| Method Summary | |
|---|---|
| protected  ServletRequestDataBinder | bindAndValidate(HttpServletRequest request,
                Object command)Bind the parameters of the given request to the given command object. | 
| protected  boolean | checkCommand(Object command)Check if the given command object is a valid for this controller, i.e. its command class. | 
| protected  ServletRequestDataBinder | createBinder(HttpServletRequest request,
             Object command)Create a new binder instance for the given command and request. | 
| protected  Object | createCommand()Create a new command instance for the command class of this controller. | 
| protected  Object | getCommand(HttpServletRequest request)Retrieve a command object for the given request. | 
|  Class | getCommandClass()Return the command class for this controller. | 
|  String | getCommandName()Return the name of the command in the model. | 
|  MessageCodesResolver | getMessageCodesResolver()Return the strategy to use for resolving errors into message codes. | 
|  Validator | getValidator() | 
|  Validator[] | getValidators() | 
| protected  void | initApplicationContext()Subclasses can override this for custom initialization behavior. | 
| protected  void | initBinder(HttpServletRequest request,
           ServletRequestDataBinder binder)Initialize the given binder instance, for example with custom editors. | 
|  boolean | isValidateOnBinding()Return if the Validator should get applied when binding. | 
| protected  void | onBind(HttpServletRequest request,
       Object command)Callback for custom post-processing in terms of binding. | 
| protected  void | onBind(HttpServletRequest request,
       Object command,
       BindException errors)Callback for custom post-processing in terms of binding. | 
| protected  void | onBindAndValidate(HttpServletRequest request,
                  Object command,
                  BindException errors)Callback for custom post-processing in terms of binding and validation. | 
|  void | setCommandClass(Class commandClass)Set the command class for this controller. | 
|  void | setCommandName(String commandName)Set the name of the command in the model. | 
|  void | setMessageCodesResolver(MessageCodesResolver messageCodesResolver)Set the strategy to use for resolving errors into message codes. | 
|  void | setValidateOnBinding(boolean validateOnBinding)Set if the Validator should get applied when binding. | 
|  void | setValidator(Validator validator)Set the primary Validator for this controller. | 
|  void | setValidators(Validator[] validators)Set the Validators for this controller. | 
| protected  boolean | suppressValidation(HttpServletRequest request)Return whether to suppress validation for the given request. | 
| Methods inherited from class org.springframework.web.servlet.mvc.AbstractController | 
|---|
| handleRequest, handleRequestInternal, isSynchronizeOnSession, setSynchronizeOnSession | 
| Methods inherited from class org.springframework.web.servlet.support.WebContentGenerator | 
|---|
| applyCacheSeconds, applyCacheSeconds, cacheForSeconds, cacheForSeconds, checkAndPrepare, checkAndPrepare, getCacheSeconds, getSupportedMethods, isRequireSession, isUseCacheControlHeader, isUseExpiresHeader, preventCaching, setCacheSeconds, setRequireSession, setSupportedMethods, setUseCacheControlHeader, setUseExpiresHeader | 
| Methods inherited from class org.springframework.web.context.support.WebApplicationObjectSupport | 
|---|
| getServletContext, getTempDir, getWebApplicationContext, isContextRequired | 
| Methods inherited from class org.springframework.context.support.ApplicationObjectSupport | 
|---|
| getApplicationContext, getMessageSourceAccessor, requiredContextClass, setApplicationContext | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
|---|
public static final String DEFAULT_COMMAND_NAME
| Constructor Detail | 
|---|
public BaseCommandController()
| Method Detail | 
|---|
public final void setCommandName(String commandName)
public final String getCommandName()
public final void setCommandClass(Class commandClass)
public final Class getCommandClass()
public final void setValidators(Validator[] validators)
public final Validator[] getValidators()
public final void setValidator(Validator validator)
setValidators(Validator[]) to set multiple validators.
public final Validator getValidator()
public final void setValidateOnBinding(boolean validateOnBinding)
public final boolean isValidateOnBinding()
public final void setMessageCodesResolver(MessageCodesResolver messageCodesResolver)
Default is null, i.e. using the default strategy of the data binder.
createBinder(javax.servlet.http.HttpServletRequest, java.lang.Object), 
DataBinder.setMessageCodesResolver(org.springframework.validation.MessageCodesResolver)public final MessageCodesResolver getMessageCodesResolver()
protected void initApplicationContext()
ApplicationObjectSupportsetApplicationContext after setting the context instance.
 Note: Does not get called on reinitialization of the context but rather just on first initialization of this object's context reference.
initApplicationContext in class ApplicationObjectSupportApplicationObjectSupport.setApplicationContext(org.springframework.context.ApplicationContext)
protected Object getCommand(HttpServletRequest request)
                     throws Exception
Default implementation calls createCommand. Subclasses can override this.
request - current HTTP request
ExceptioncreateCommand()
protected final Object createCommand()
                              throws InstantiationException,
                                     IllegalAccessException
InstantiationException - if the command class could not be instantiated
IllegalAccessException - if the class or its constructor is not accessibleprotected final boolean checkCommand(Object command)
command - the command object to check
protected final ServletRequestDataBinder bindAndValidate(HttpServletRequest request,
                                                         Object command)
                                                  throws Exception
request - current HTTP requestcommand - the command to bind onto
Exception - in case of invalid state or arguments
protected ServletRequestDataBinder createBinder(HttpServletRequest request,
                                                Object command)
                                         throws Exception
Called by bindAndValidate. Can be overridden to plug in
 custom ServletRequestDataBinder subclasses.
 
Default implementation creates a standard ServletRequestDataBinder,
 sets the specified MessageCodesResolver (if any), and invokes initBinder.
 Note that initBinder will not be invoked if you override this method!
request - current HTTP requestcommand - the command to bind onto
Exception - in case of invalid state or argumentsbindAndValidate(javax.servlet.http.HttpServletRequest, java.lang.Object), 
initBinder(javax.servlet.http.HttpServletRequest, org.springframework.web.bind.ServletRequestDataBinder), 
setMessageCodesResolver(org.springframework.validation.MessageCodesResolver)
protected void initBinder(HttpServletRequest request,
                          ServletRequestDataBinder binder)
                   throws Exception
createBinder.
 This method allows you to register custom editors for certain fields of your command class. For instance, you will be able to transform Date objects into a String pattern and back, in order to allow your JavaBeans to have Date properties and still be able to set and display them in an HTML interface.
Default implementation is empty.
request - current HTTP requestbinder - new binder instance
Exception - in case of invalid state or argumentscreateBinder(javax.servlet.http.HttpServletRequest, java.lang.Object), 
DataBinder.registerCustomEditor(java.lang.Class, java.beans.PropertyEditor), 
CustomDateEditor
protected void onBind(HttpServletRequest request,
                      Object command,
                      BindException errors)
               throws Exception
Default implementation delegates to onBind(request, command).
request - current HTTP requestcommand - the command object to perform further binding onerrors - validation errors holder, allowing for additional
 custom registration of binding errors
Exception - in case of invalid state or argumentsbindAndValidate(javax.servlet.http.HttpServletRequest, java.lang.Object), 
onBind(HttpServletRequest, Object)
protected void onBind(HttpServletRequest request,
                      Object command)
               throws Exception
Default implementation is empty.
request - current HTTP requestcommand - the command object to perform further binding on
Exception - in case of invalid state or argumentsonBind(HttpServletRequest, Object, BindException)protected boolean suppressValidation(HttpServletRequest request)
Default implementation always returns false. Can be overridden in subclasses to suppress validation, for example, if a special request parameter is set.
request - current HTTP request
protected void onBindAndValidate(HttpServletRequest request,
                                 Object command,
                                 BindException errors)
                          throws Exception
Default implementation is empty.
request - current HTTP requestcommand - the command object, still allowing for further bindingerrors - validation errors holder, allowing for additional
 custom validation
Exception - in case of invalid state or argumentsbindAndValidate(javax.servlet.http.HttpServletRequest, java.lang.Object), 
Errors| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||