Package org.apache.commons.validator
Class Validator
- java.lang.Object
-
- org.apache.commons.validator.Validator
-
- All Implemented Interfaces:
java.io.Serializable
public class Validator extends java.lang.Object implements java.io.Serializable
Validations are processed by the validate method. An instance ofValidatorResourcesis used to define the validators (validation methods) and the validation rules for a JavaBean.- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static java.lang.StringBEAN_PARAMResources key the JavaBean is stored to perform validation on.protected java.lang.ClassLoaderclassLoaderDeprecated.UsegetClassLoader(), will be private in the next major version.static java.lang.StringFIELD_PARAMResources key theFieldis stored under.protected java.lang.StringfieldNameDeprecated.UsegetFieldName(), will be private in the next major version.static java.lang.StringFORM_PARAMResources key theFormis stored under.protected java.lang.StringformNameDeprecated.UsegetFormName(), will be private in the next major version.static java.lang.StringLOCALE_PARAMResources key theLocaleis stored.protected booleanonlyReturnErrorsDeprecated.UsegetOnlyReturnErrors(), will be private in the next major version.protected intpageDeprecated.UsegetPage(), will be private in the next major version.protected java.util.Map<java.lang.String,java.lang.Object>parametersDeprecated.UsegetParameters(), will be private in the next major version.protected ValidatorResourcesresourcesDeprecated.UsegetResources(), will be private in the next major version.protected booleanuseContextClassLoaderDeprecated.UsegetUseContextClassLoader(), will be private in the next major version.static java.lang.StringVALIDATOR_ACTION_PARAMResources key theValidatorActionis stored under.static java.lang.StringVALIDATOR_PARAMResources key theValidatoris stored under.static java.lang.StringVALIDATOR_RESULTS_PARAMResources key theValidatorResultsis stored under.
-
Constructor Summary
Constructors Constructor Description Validator(ValidatorResources resources)Constructs aValidatorthat will use theValidatorResourcespassed in to retrieve pluggable validators the different sets of validation rules.Validator(ValidatorResources resources, java.lang.String formName)Constructs aValidatorthat will use theValidatorResourcespassed in to retrieve pluggable validators the different sets of validation rules.Validator(ValidatorResources resources, java.lang.String formName, java.lang.String fieldName)Constructs aValidatorthat will use theValidatorResourcespassed in to retrieve pluggable validators the different sets of validation rules.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclear()Clears the form name, resources that were added, and the page that was set (if any).java.lang.ClassLoadergetClassLoader()Gets the class loader to be used for instantiating application objects when required.java.lang.StringgetFieldName()Gets the field name.java.lang.StringgetFormName()Gets the form name which is the key to a set of validation rules.booleangetOnlyReturnErrors()Returns true if the Validator is only returning Fields that fail validation.intgetPage()Gets the page.java.util.Map<java.lang.String,java.lang.Object>getParameters()Gets the parameter map.java.lang.ObjectgetParameterValue(java.lang.String parameterClassName)Returns the value of the specified parameter that will be used during the processing of validations.ValidatorResourcesgetResources()Gets the validator resource.booleangetUseContextClassLoader()Gets the boolean as to whether the context classloader should be used.voidsetClassLoader(java.lang.ClassLoader classLoader)Sets the class loader to be used for instantiating application objects when required.voidsetFieldName(java.lang.String fieldName)Sets the name of the field to validate in a form (optional)voidsetFormName(java.lang.String formName)Sets the form name which is the key to a set of validation rules.voidsetOnlyReturnErrors(boolean onlyReturnErrors)Configures which Fields the Validator returns from the validate() method.voidsetPage(int page)Sets the page.voidsetParameter(java.lang.String parameterClassName, java.lang.Object parameterValue)Sets a parameter of a pluggable validation method.voidsetUseContextClassLoader(boolean useContextClassLoader)Sets whether to use the Context ClassLoader (the one found by callingThread.currentThread().getContextClassLoader()) to resolve/load classes that are defined in various rules.ValidatorResultsvalidate()Performs validations based on the configured resources.
-
-
-
Field Detail
-
BEAN_PARAM
public static final java.lang.String BEAN_PARAM
Resources key the JavaBean is stored to perform validation on.- See Also:
- Constant Field Values
-
VALIDATOR_ACTION_PARAM
public static final java.lang.String VALIDATOR_ACTION_PARAM
Resources key theValidatorActionis stored under. This will be automatically passed into a validation method with the currentValidatorActionif it is specified in the method signature.- See Also:
- Constant Field Values
-
VALIDATOR_RESULTS_PARAM
public static final java.lang.String VALIDATOR_RESULTS_PARAM
Resources key theValidatorResultsis stored under. This will be automatically passed into a validation method with the currentValidatorResultsif it is specified in the method signature.- See Also:
- Constant Field Values
-
FORM_PARAM
public static final java.lang.String FORM_PARAM
Resources key theFormis stored under. This will be automatically passed into a validation method with the currentFormif it is specified in the method signature.- See Also:
- Constant Field Values
-
FIELD_PARAM
public static final java.lang.String FIELD_PARAM
Resources key theFieldis stored under. This will be automatically passed into a validation method with the currentFieldif it is specified in the method signature.- See Also:
- Constant Field Values
-
VALIDATOR_PARAM
public static final java.lang.String VALIDATOR_PARAM
Resources key theValidatoris stored under. This will be automatically passed into a validation method with the currentValidatorif it is specified in the method signature.- See Also:
- Constant Field Values
-
LOCALE_PARAM
public static final java.lang.String LOCALE_PARAM
Resources key theLocaleis stored. This will be used to retrieve the appropriateFormSetandFormto be processed.- See Also:
- Constant Field Values
-
resources
@Deprecated protected ValidatorResources resources
Deprecated.UsegetResources(), will be private in the next major version.The Validator Resources.
-
formName
@Deprecated protected java.lang.String formName
Deprecated.UsegetFormName(), will be private in the next major version.The name of the form to validate
-
fieldName
@Deprecated protected java.lang.String fieldName
Deprecated.UsegetFieldName(), will be private in the next major version.The name of the field on the form to validate- Since:
- 1.2.0
-
parameters
@Deprecated protected java.util.Map<java.lang.String,java.lang.Object> parameters
Deprecated.UsegetParameters(), will be private in the next major version.Maps validation method parameter class names to the objects to be passed into the method.
-
page
@Deprecated protected int page
Deprecated.UsegetPage(), will be private in the next major version.The current page number to validate.
-
classLoader
@Deprecated protected transient java.lang.ClassLoader classLoader
Deprecated.UsegetClassLoader(), will be private in the next major version.The class loader to use for instantiating application objects. If not specified, the context class loader, or the class loader used to load Digester itself, is used, based on the value of theuseContextClassLoadervariable.
-
useContextClassLoader
@Deprecated protected boolean useContextClassLoader
Deprecated.UsegetUseContextClassLoader(), will be private in the next major version.Whether or not to use the Context ClassLoader when loading classes for instantiating new objects. Default isfalse.
-
onlyReturnErrors
@Deprecated protected boolean onlyReturnErrors
Deprecated.UsegetOnlyReturnErrors(), will be private in the next major version.Sets this to true to not return Fields that pass validation. Only return failures.
-
-
Constructor Detail
-
Validator
public Validator(ValidatorResources resources)
Constructs aValidatorthat will use theValidatorResourcespassed in to retrieve pluggable validators the different sets of validation rules.- Parameters:
resources-ValidatorResourcesto use during validation.
-
Validator
public Validator(ValidatorResources resources, java.lang.String formName)
Constructs aValidatorthat will use theValidatorResourcespassed in to retrieve pluggable validators the different sets of validation rules.- Parameters:
resources-ValidatorResourcesto use during validation.formName- Key used for retrieving the set of validation rules.
-
Validator
public Validator(ValidatorResources resources, java.lang.String formName, java.lang.String fieldName)
Constructs aValidatorthat will use theValidatorResourcespassed in to retrieve pluggable validators the different sets of validation rules.- Parameters:
resources-ValidatorResourcesto use during validation.formName- Key used for retrieving the set of validation rules.fieldName- Key used for retrieving the set of validation rules for a field- Since:
- 1.2.0
-
-
Method Detail
-
clear
public void clear()
Clears the form name, resources that were added, and the page that was set (if any). This can be called to reinitialize the Validator instance so it can be reused. The form name (key to set of validation rules) and any resources needed, like the JavaBean being validated, will need to set and/or added to this instance again. TheValidatorResourceswill not be removed since it can be used again and is thread safe.
-
getClassLoader
public java.lang.ClassLoader getClassLoader()
Gets the class loader to be used for instantiating application objects when required. This is determined based upon the following rules:- The class loader set by
setClassLoader(), if any - The thread context class loader, if it exists and the
useContextClassLoaderproperty is set to true - The class loader used to load the Digester class itself.
- Returns:
- the class loader.
- The class loader set by
-
getFieldName
public java.lang.String getFieldName()
Gets the field name.- Returns:
- the field name.
- Since:
- 1.10.0
-
getFormName
public java.lang.String getFormName()
Gets the form name which is the key to a set of validation rules.- Returns:
- the name of the form.
-
getOnlyReturnErrors
public boolean getOnlyReturnErrors()
Returns true if the Validator is only returning Fields that fail validation.- Returns:
- whether only failed fields are returned.
-
getPage
public int getPage()
Gets the page.This in conjunction with the page property of a
Fieldcan control the processing of fields. If the field's page is less than or equal to this page value, it will be processed.- Returns:
- the page number.
-
getParameters
public java.util.Map<java.lang.String,java.lang.Object> getParameters()
Gets the parameter map.- Returns:
- the parameter map.
- Since:
- 1.10.0
-
getParameterValue
public java.lang.Object getParameterValue(java.lang.String parameterClassName)
Returns the value of the specified parameter that will be used during the processing of validations.- Parameters:
parameterClassName- The full class name of the parameter of the validation method that corresponds to the value/instance passed in with it.- Returns:
- value of the specified parameter.
-
getResources
public ValidatorResources getResources()
Gets the validator resource.- Returns:
- the validator resource.
- Since:
- 1.10.0
-
getUseContextClassLoader
public boolean getUseContextClassLoader()
Gets the boolean as to whether the context classloader should be used.- Returns:
- whether the context classloader should be used.
-
setClassLoader
public void setClassLoader(java.lang.ClassLoader classLoader)
Sets the class loader to be used for instantiating application objects when required.- Parameters:
classLoader- The new class loader to use, ornullto revert to the standard rules
-
setFieldName
public void setFieldName(java.lang.String fieldName)
Sets the name of the field to validate in a form (optional)- Parameters:
fieldName- The name of the field in a form set- Since:
- 1.2.0
-
setFormName
public void setFormName(java.lang.String formName)
Sets the form name which is the key to a set of validation rules.- Parameters:
formName- the name of the form.
-
setOnlyReturnErrors
public void setOnlyReturnErrors(boolean onlyReturnErrors)
Configures which Fields the Validator returns from the validate() method. Set this to true to only return Fields that failed validation. By default, validate() returns all fields.- Parameters:
onlyReturnErrors- whether only failed fields are returned.
-
setPage
public void setPage(int page)
Sets the page.This in conjunction with the page property of a
Fieldcan control the processing of fields. If the field's page is less than or equal to this page value, it will be processed.- Parameters:
page- the page number.
-
setParameter
public void setParameter(java.lang.String parameterClassName, java.lang.Object parameterValue)
Sets a parameter of a pluggable validation method.- Parameters:
parameterClassName- The full class name of the parameter of the validation method that corresponds to the value/instance passed in with it.parameterValue- The instance that will be passed into the validation method.
-
setUseContextClassLoader
public void setUseContextClassLoader(boolean useContextClassLoader)
Sets whether to use the Context ClassLoader (the one found by callingThread.currentThread().getContextClassLoader()) to resolve/load classes that are defined in various rules. If not using Context ClassLoader, then the class-loading defaults to using the calling-class' ClassLoader.- Parameters:
useContextClassLoader- determines whether to use Context ClassLoader.
-
validate
public ValidatorResults validate() throws ValidatorException
Performs validations based on the configured resources.- Returns:
- The
Mapreturned uses the property of theFieldfor the key and the value is the number of error the field had. - Throws:
ValidatorException- If an error occurs during validation
-
-