Class DataBinder
- All Implemented Interfaces:
- org.springframework.beans.PropertyEditorRegistry,- org.springframework.beans.TypeConverter
The binding process can be customized by specifying allowed field patterns, required fields, custom editors, etc.
WARNING: Data binding can lead to security issues by exposing parts of the object graph that are not meant to be accessed or modified by external clients. Therefore, the design and use of data binding should be considered carefully with regard to security. For more details, please refer to the dedicated sections on data binding for Spring Web MVC and Spring WebFlux in the reference manual.
The binding results can be examined via the BindingResult interface,
 extending the Errors interface: see the getBindingResult() method.
 Missing fields and property access exceptions will be converted to FieldErrors,
 collected in the Errors instance, using the following error codes:
 
- Missing field error: "required"
- Type mismatch error: "typeMismatch"
- Method invocation error: "methodInvocation"
By default, binding errors get resolved through the BindingErrorProcessor
 strategy, processing for missing fields and property access exceptions: see the
 setBindingErrorProcessor(org.springframework.validation.BindingErrorProcessor) method. You can override the default strategy
 if needed, for example to generate different error codes.
 
Custom validation errors can be added afterwards. You will typically want to resolve
 such error codes into proper user-visible error messages; this can be achieved through
 resolving each error via a MessageSource, which is
 able to resolve an ObjectError/FieldError through its
 MessageSource.getMessage(org.springframework.context.MessageSourceResolvable, java.util.Locale)
 method. The list of message codes can be customized through the MessageCodesResolver
 strategy: see the setMessageCodesResolver(org.springframework.validation.MessageCodesResolver) method. DefaultMessageCodesResolver's
 javadoc states details on the default resolution rules.
 
This generic data binder can be used in any kind of environment.
- Author:
- Rod Johnson, Juergen Hoeller, Rob Harrop, Stephane Nicoll, Kazuki Shimizu, Sam Brannen
- See Also:
- 
- setAllowedFields(java.lang.String...)
- setRequiredFields(java.lang.String...)
- registerCustomEditor(java.lang.Class<?>, java.beans.PropertyEditor)
- setMessageCodesResolver(org.springframework.validation.MessageCodesResolver)
- setBindingErrorProcessor(org.springframework.validation.BindingErrorProcessor)
- bind(org.springframework.beans.PropertyValues)
- getBindingResult()
- DefaultMessageCodesResolver
- DefaultBindingErrorProcessor
- MessageSource
 
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intDefault limit for array and collection growing: 256.static final StringDefault object name used for binding: "target".protected static final org.apache.commons.logging.LogWe'll create a lot of DataBinder instances: Let's use a static logger.
- 
Constructor SummaryConstructorsConstructorDescriptionDataBinder(Object target) Create a new DataBinder instance, with default object name.DataBinder(Object target, String objectName) Create a new DataBinder instance.
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddCustomFormatter(Formatter<?> formatter) Add a custom formatter, applying it to all fields matching theFormatter-declared type.voidaddCustomFormatter(Formatter<?> formatter, Class<?>... fieldTypes) Add a custom formatter, applying it to the specified field types only, if any, or otherwise to all fields matching theFormatter-declared type.voidaddCustomFormatter(Formatter<?> formatter, String... fields) Add a custom formatter for the field type specified inFormatterclass, applying it to the specified fields only, if any, or otherwise to all fields.voidaddValidators(Validator... validators) Add Validators to apply after each binding step.protected voidapplyPropertyValues(org.springframework.beans.MutablePropertyValues mpvs) Apply given property values to the target object.voidbind(org.springframework.beans.PropertyValues pvs) Bind the given property values to this binder's target.protected voidcheckAllowedFields(org.springframework.beans.MutablePropertyValues mpvs) Check the given property values against the allowed fields, removing values for fields that are not allowed.protected voidcheckRequiredFields(org.springframework.beans.MutablePropertyValues mpvs) Check the given property values against the required fields, generating missing field errors where appropriate.Map<?,?> close()Close this DataBinder, which may result in throwing a BindException if it encountered any errors.<T> TconvertIfNecessary(Object value, Class<T> requiredType) <T> TconvertIfNecessary(Object value, Class<T> requiredType, Field field) <T> TconvertIfNecessary(Object value, Class<T> requiredType, org.springframework.core.convert.TypeDescriptor typeDescriptor) <T> TconvertIfNecessary(Object value, Class<T> requiredType, org.springframework.core.MethodParameter methodParam) protected AbstractPropertyBindingResultCreate theAbstractPropertyBindingResultinstance using standard JavaBean property access.protected AbstractPropertyBindingResultCreate theAbstractPropertyBindingResultinstance using direct field access.protected voiddoBind(org.springframework.beans.MutablePropertyValues mpvs) Actual implementation of the binding process, working with the passed-in MutablePropertyValues instance.findCustomEditor(Class<?> requiredType, String propertyPath) String[]Return the field patterns that should be allowed for binding.intReturn the current limit for array and collection auto-growing.Return the strategy for processing binding errors.Return the BindingResult instance created by this DataBinder.org.springframework.core.convert.ConversionServiceReturn the associated ConversionService, if any.String[]Return the field patterns that should not be allowed for binding.protected AbstractPropertyBindingResultReturn the internal BindingResult held by this DataBinder, as an AbstractPropertyBindingResult.Return the name of the bound object.protected org.springframework.beans.ConfigurablePropertyAccessorReturn the underlying PropertyAccessor of this binder's BindingResult.protected org.springframework.beans.PropertyEditorRegistryReturn the underlying TypeConverter of this binder's BindingResult.String[]Return the fields that are required for each binding process.protected org.springframework.beans.SimpleTypeConverterReturn this binder's underlying SimpleTypeConverter.Return the wrapped target object.protected org.springframework.beans.TypeConverterReturn the underlying TypeConverter of this binder's BindingResult.Return the primary Validator to apply after each binding step, if any.Return the Validators to apply after data binding.voidInitialize standard JavaBean property access for this DataBinder.voidInitialize direct field access for this DataBinder, as alternative to the default bean property access.protected booleanDetermine if the given field is allowed for binding.booleanReturn whether "auto-growing" of nested paths has been activated.booleanReturn whether to ignore invalid fields when binding.booleanReturn whether to ignore unknown fields when binding.voidregisterCustomEditor(Class<?> requiredType, PropertyEditor propertyEditor) voidregisterCustomEditor(Class<?> requiredType, String field, PropertyEditor propertyEditor) voidreplaceValidators(Validator... validators) Replace the Validators to apply after each binding step.voidsetAllowedFields(String... allowedFields) Register field patterns that should be allowed for binding.voidsetAutoGrowCollectionLimit(int autoGrowCollectionLimit) Specify the limit for array and collection auto-growing.voidsetAutoGrowNestedPaths(boolean autoGrowNestedPaths) Set whether this binder should attempt to "auto-grow" a nested path that contains a null value.voidsetBindingErrorProcessor(BindingErrorProcessor bindingErrorProcessor) Set the strategy to use for processing binding errors, that is, required field errors andPropertyAccessExceptions.voidsetConversionService(org.springframework.core.convert.ConversionService conversionService) Specify aConversionServiceto use for converting property values, as an alternative to JavaBeans PropertyEditors.voidsetDisallowedFields(String... disallowedFields) Register field patterns that should not be allowed for binding.voidsetIgnoreInvalidFields(boolean ignoreInvalidFields) Set whether to ignore invalid fields, that is, whether to ignore bind parameters that have corresponding fields in the target object which are not accessible (for example because of null values in the nested path).voidsetIgnoreUnknownFields(boolean ignoreUnknownFields) Set whether to ignore unknown fields, that is, whether to ignore bind parameters that do not have corresponding fields in the target object.voidsetMessageCodesResolver(MessageCodesResolver messageCodesResolver) Set the strategy to use for resolving errors into message codes.voidsetRequiredFields(String... requiredFields) Register fields that are required for each binding process.voidsetValidator(Validator validator) Set the Validator to apply after each binding step.voidvalidate()Invoke the specified Validators, if any.voidInvoke the specified Validators, if any, with the given validation hints.
- 
Field Details- 
DEFAULT_OBJECT_NAMEDefault object name used for binding: "target".- See Also:
 
- 
DEFAULT_AUTO_GROW_COLLECTION_LIMITpublic static final int DEFAULT_AUTO_GROW_COLLECTION_LIMITDefault limit for array and collection growing: 256.- See Also:
 
- 
loggerprotected static final org.apache.commons.logging.Log loggerWe'll create a lot of DataBinder instances: Let's use a static logger.
 
- 
- 
Constructor Details- 
DataBinderCreate a new DataBinder instance, with default object name.- Parameters:
- target- the target object to bind onto (or- nullif the binder is just used to convert a plain parameter value)
- See Also:
 
- 
DataBinderCreate a new DataBinder instance.- Parameters:
- target- the target object to bind onto (or- nullif the binder is just used to convert a plain parameter value)
- objectName- the name of the target object
 
 
- 
- 
Method Details- 
getTargetReturn the wrapped target object.
- 
getObjectNameReturn the name of the bound object.
- 
setAutoGrowNestedPathspublic void setAutoGrowNestedPaths(boolean autoGrowNestedPaths) Set whether this binder should attempt to "auto-grow" a nested path that contains a null value.If "true", a null path location will be populated with a default object value and traversed instead of resulting in an exception. This flag also enables auto-growth of collection elements when accessing an out-of-bounds index. Default is "true" on a standard DataBinder. Note that since Spring 4.1 this feature is supported for bean property access (DataBinder's default mode) and field access. - See Also:
- 
- initBeanPropertyAccess()
- ConfigurablePropertyAccessor.setAutoGrowNestedPaths(boolean)
 
 
- 
isAutoGrowNestedPathspublic boolean isAutoGrowNestedPaths()Return whether "auto-growing" of nested paths has been activated.
- 
setAutoGrowCollectionLimitpublic void setAutoGrowCollectionLimit(int autoGrowCollectionLimit) Specify the limit for array and collection auto-growing.Default is 256, preventing OutOfMemoryErrors in case of large indexes. Raise this limit if your auto-growing needs are unusually high. - See Also:
- 
- initBeanPropertyAccess()
- BeanWrapper.setAutoGrowCollectionLimit(int)
 
 
- 
getAutoGrowCollectionLimitpublic int getAutoGrowCollectionLimit()Return the current limit for array and collection auto-growing.
- 
initBeanPropertyAccesspublic void initBeanPropertyAccess()Initialize standard JavaBean property access for this DataBinder.This is the default; an explicit call just leads to eager initialization. 
- 
createBeanPropertyBindingResultCreate theAbstractPropertyBindingResultinstance using standard JavaBean property access.- Since:
- 4.2.1
 
- 
initDirectFieldAccesspublic void initDirectFieldAccess()Initialize direct field access for this DataBinder, as alternative to the default bean property access.
- 
createDirectFieldBindingResultCreate theAbstractPropertyBindingResultinstance using direct field access.- Since:
- 4.2.1
 
- 
getInternalBindingResultReturn the internal BindingResult held by this DataBinder, as an AbstractPropertyBindingResult.
- 
getPropertyAccessorprotected org.springframework.beans.ConfigurablePropertyAccessor getPropertyAccessor()Return the underlying PropertyAccessor of this binder's BindingResult.
- 
getSimpleTypeConverterprotected org.springframework.beans.SimpleTypeConverter getSimpleTypeConverter()Return this binder's underlying SimpleTypeConverter.
- 
getPropertyEditorRegistryprotected org.springframework.beans.PropertyEditorRegistry getPropertyEditorRegistry()Return the underlying TypeConverter of this binder's BindingResult.
- 
getTypeConverterprotected org.springframework.beans.TypeConverter getTypeConverter()Return the underlying TypeConverter of this binder's BindingResult.
- 
getBindingResultReturn the BindingResult instance created by this DataBinder. This allows for convenient access to the binding results after a bind operation.- Returns:
- the BindingResult instance, to be treated as BindingResult or as Errors instance (Errors is a super-interface of BindingResult)
- See Also:
 
- 
setIgnoreUnknownFieldspublic void setIgnoreUnknownFields(boolean ignoreUnknownFields) Set whether to ignore unknown fields, that is, whether to ignore bind parameters that do not have corresponding fields in the target object.Default is "true". Turn this off to enforce that all bind parameters must have a matching field in the target object. Note that this setting only applies to binding operations on this DataBinder, not to retrieving values via its BindingResult.
- 
isIgnoreUnknownFieldspublic boolean isIgnoreUnknownFields()Return whether to ignore unknown fields when binding.
- 
setIgnoreInvalidFieldspublic void setIgnoreInvalidFields(boolean ignoreInvalidFields) Set whether to ignore invalid fields, that is, whether to ignore bind parameters that have corresponding fields in the target object which are not accessible (for example because of null values in the nested path).Default is "false". Turn this on to ignore bind parameters for nested objects in non-existing parts of the target object graph. Note that this setting only applies to binding operations on this DataBinder, not to retrieving values via its BindingResult.
- 
isIgnoreInvalidFieldspublic boolean isIgnoreInvalidFields()Return whether to ignore invalid fields when binding.
- 
setAllowedFieldsRegister field patterns that should be allowed for binding.Default is all fields. Restrict this for example to avoid unwanted modifications by malicious users when binding HTTP request parameters. Supports "xxx*","*xxx","*xxx*", and"xxx*yyy"matches (with an arbitrary number of pattern parts), as well as direct equality.The default implementation of this method stores allowed field patterns in canonical form. Subclasses which override this method must therefore take this into account. More sophisticated matching can be implemented by overriding the isAllowed(java.lang.String)method.Alternatively, specify a list of disallowed field patterns. - Parameters:
- allowedFields- array of allowed field patterns
- See Also:
 
- 
getAllowedFieldsReturn the field patterns that should be allowed for binding.- Returns:
- array of allowed field patterns
- See Also:
 
- 
setDisallowedFieldsRegister field patterns that should not be allowed for binding.Default is none. Mark fields as disallowed, for example to avoid unwanted modifications by malicious users when binding HTTP request parameters. Supports "xxx*","*xxx","*xxx*", and"xxx*yyy"matches (with an arbitrary number of pattern parts), as well as direct equality.The default implementation of this method stores disallowed field patterns in canonical form. As of Spring Framework 5.2.21, the default implementation also transforms disallowed field patterns to lowercase to support case-insensitive pattern matching in isAllowed(java.lang.String). Subclasses which override this method must therefore take both of these transformations into account.More sophisticated matching can be implemented by overriding the isAllowed(java.lang.String)method.Alternatively, specify a list of allowed field patterns. - Parameters:
- disallowedFields- array of disallowed field patterns
- See Also:
 
- 
getDisallowedFieldsReturn the field patterns that should not be allowed for binding.- Returns:
- array of disallowed field patterns
- See Also:
 
- 
setRequiredFieldsRegister fields that are required for each binding process.If one of the specified fields is not contained in the list of incoming property values, a corresponding "missing field" error will be created, with error code "required" (by the default binding error processor). - Parameters:
- requiredFields- array of field names
- See Also:
 
- 
getRequiredFieldsReturn the fields that are required for each binding process.- Returns:
- array of field names
 
- 
setMessageCodesResolverSet the strategy to use for resolving errors into message codes. Applies the given strategy to the underlying errors holder.Default is a DefaultMessageCodesResolver. 
- 
setBindingErrorProcessorSet the strategy to use for processing binding errors, that is, required field errors andPropertyAccessExceptions.Default is a DefaultBindingErrorProcessor. - See Also:
 
- 
getBindingErrorProcessorReturn the strategy for processing binding errors.
- 
setValidatorSet the Validator to apply after each binding step.
- 
addValidatorsAdd Validators to apply after each binding step.
- 
replaceValidatorsReplace the Validators to apply after each binding step.
- 
getValidatorReturn the primary Validator to apply after each binding step, if any.
- 
getValidatorsReturn the Validators to apply after data binding.
- 
setConversionServicepublic void setConversionService(@Nullable org.springframework.core.convert.ConversionService conversionService) Specify aConversionServiceto use for converting property values, as an alternative to JavaBeans PropertyEditors.
- 
getConversionService@Nullable public org.springframework.core.convert.ConversionService getConversionService()Return the associated ConversionService, if any.
- 
addCustomFormatterAdd a custom formatter, applying it to all fields matching theFormatter-declared type.Registers a corresponding PropertyEditoradapter underneath the covers.- Parameters:
- formatter- the formatter to add, generically declared for a specific type
- Since:
- 4.2
- See Also:
 
- 
addCustomFormatterAdd a custom formatter for the field type specified inFormatterclass, applying it to the specified fields only, if any, or otherwise to all fields.Registers a corresponding PropertyEditoradapter underneath the covers.- Parameters:
- formatter- the formatter to add, generically declared for a specific type
- fields- the fields to apply the formatter to, or none if to be applied to all
- Since:
- 4.2
- See Also:
 
- 
addCustomFormatterAdd a custom formatter, applying it to the specified field types only, if any, or otherwise to all fields matching theFormatter-declared type.Registers a corresponding PropertyEditoradapter underneath the covers.- Parameters:
- formatter- the formatter to add (does not need to generically declare a field type if field types are explicitly specified as parameters)
- fieldTypes- the field types to apply the formatter to, or none if to be derived from the given- Formatterimplementation class
- Since:
- 4.2
- See Also:
 
- 
registerCustomEditor- Specified by:
- registerCustomEditorin interface- org.springframework.beans.PropertyEditorRegistry
 
- 
registerCustomEditorpublic void registerCustomEditor(@Nullable Class<?> requiredType, @Nullable String field, PropertyEditor propertyEditor) - Specified by:
- registerCustomEditorin interface- org.springframework.beans.PropertyEditorRegistry
 
- 
findCustomEditor@Nullable public PropertyEditor findCustomEditor(@Nullable Class<?> requiredType, @Nullable String propertyPath) - Specified by:
- findCustomEditorin interface- org.springframework.beans.PropertyEditorRegistry
 
- 
convertIfNecessary@Nullable public <T> T convertIfNecessary(@Nullable Object value, @Nullable Class<T> requiredType) throws org.springframework.beans.TypeMismatchException - Specified by:
- convertIfNecessaryin interface- org.springframework.beans.TypeConverter
- Throws:
- org.springframework.beans.TypeMismatchException
 
- 
convertIfNecessary@Nullable public <T> T convertIfNecessary(@Nullable Object value, @Nullable Class<T> requiredType, @Nullable org.springframework.core.MethodParameter methodParam) throws org.springframework.beans.TypeMismatchException - Specified by:
- convertIfNecessaryin interface- org.springframework.beans.TypeConverter
- Throws:
- org.springframework.beans.TypeMismatchException
 
- 
convertIfNecessary@Nullable public <T> T convertIfNecessary(@Nullable Object value, @Nullable Class<T> requiredType, @Nullable Field field) throws org.springframework.beans.TypeMismatchException - Specified by:
- convertIfNecessaryin interface- org.springframework.beans.TypeConverter
- Throws:
- org.springframework.beans.TypeMismatchException
 
- 
convertIfNecessary@Nullable public <T> T convertIfNecessary(@Nullable Object value, @Nullable Class<T> requiredType, @Nullable org.springframework.core.convert.TypeDescriptor typeDescriptor) throws org.springframework.beans.TypeMismatchException - Specified by:
- convertIfNecessaryin interface- org.springframework.beans.TypeConverter
- Throws:
- org.springframework.beans.TypeMismatchException
 
- 
bindpublic void bind(org.springframework.beans.PropertyValues pvs) Bind the given property values to this binder's target.This call can create field errors, representing basic binding errors like a required field (code "required"), or type mismatch between value and bean property (code "typeMismatch"). Note that the given PropertyValues should be a throwaway instance: For efficiency, it will be modified to just contain allowed fields if it implements the MutablePropertyValues interface; else, an internal mutable copy will be created for this purpose. Pass in a copy of the PropertyValues if you want your original instance to stay unmodified in any case. - Parameters:
- pvs- property values to bind
- See Also:
 
- 
doBindprotected void doBind(org.springframework.beans.MutablePropertyValues mpvs) Actual implementation of the binding process, working with the passed-in MutablePropertyValues instance.- Parameters:
- mpvs- the property values to bind, as MutablePropertyValues instance
- See Also:
 
- 
checkAllowedFieldsprotected void checkAllowedFields(org.springframework.beans.MutablePropertyValues mpvs) Check the given property values against the allowed fields, removing values for fields that are not allowed.- Parameters:
- mpvs- the property values to be bound (can be modified)
- See Also:
 
- 
isAllowedDetermine if the given field is allowed for binding.Invoked for each passed-in property value. Checks for "xxx*","*xxx","*xxx*", and"xxx*yyy"matches (with an arbitrary number of pattern parts), as well as direct equality, in the configured lists of allowed field patterns and disallowed field patterns.Matching against allowed field patterns is case-sensitive; whereas, matching against disallowed field patterns is case-insensitive. A field matching a disallowed pattern will not be accepted even if it also happens to match a pattern in the allowed list. Can be overridden in subclasses, but care must be taken to honor the aforementioned contract. - Parameters:
- field- the field to check
- Returns:
- trueif the field is allowed
- See Also:
- 
- setAllowedFields(java.lang.String...)
- setDisallowedFields(java.lang.String...)
- PatternMatchUtils.simpleMatch(String, String)
 
 
- 
checkRequiredFieldsprotected void checkRequiredFields(org.springframework.beans.MutablePropertyValues mpvs) Check the given property values against the required fields, generating missing field errors where appropriate.- Parameters:
- mpvs- the property values to be bound (can be modified)
- See Also:
 
- 
applyPropertyValuesprotected void applyPropertyValues(org.springframework.beans.MutablePropertyValues mpvs) Apply given property values to the target object.Default implementation applies all the supplied property values as bean property values. By default, unknown fields will be ignored. - Parameters:
- mpvs- the property values to be bound (can be modified)
- See Also:
 
- 
validatepublic void validate()Invoke the specified Validators, if any.- See Also:
 
- 
validateInvoke the specified Validators, if any, with the given validation hints.Note: Validation hints may get ignored by the actual target Validator. - Parameters:
- validationHints- one or more hint objects to be passed to a- SmartValidator
- Since:
- 3.1
- See Also:
 
- 
closeClose this DataBinder, which may result in throwing a BindException if it encountered any errors.- Returns:
- the model Map, containing target object and Errors instance
- Throws:
- BindException- if there were any errors in the bind operation
- See Also:
 
 
-