Interface Validator
- All Known Subinterfaces:
SmartValidator
- All Known Implementing Classes:
CustomValidatorBean
,LocalValidatorFactoryBean
,OptionalValidatorFactoryBean
,SpringValidatorAdapter
This interface is totally divorced from any infrastructure or context; that is to say it is not coupled to validating only objects in the web tier, the data-access tier, or the whatever-tier. As such it is amenable to being used in any layer of an application, and supports the encapsulation of validation logic as a first-class citizen in its own right.
Implementations can be created via the static factory methods
forInstanceOf(Class, BiConsumer)
or
forType(Class, BiConsumer)
.
Below is a simple but complete Validator
that validates that the
various String
properties of a UserLogin
instance are not
empty (they are not null
and do not consist
wholly of whitespace), and that any password that is present is
at least 'MINIMUM_PASSWORD_LENGTH'
characters in length.
Validator userLoginValidator = Validator.forInstance(UserLogin.class, (login, errors) -> { ValidationUtils.rejectIfEmptyOrWhitespace(errors, "userName", "field.required"); ValidationUtils.rejectIfEmptyOrWhitespace(errors, "password", "field.required"); if (login.getPassword() != null && login.getPassword().trim().length() < MINIMUM_PASSWORD_LENGTH) { errors.rejectValue("password", "field.min.length", new Object[]{Integer.valueOf(MINIMUM_PASSWORD_LENGTH)}, "The password must be at least [" + MINIMUM_PASSWORD_LENGTH + "] characters in length."); } });
See also the Spring reference manual for a fuller discussion of
the Validator
interface and its role in an enterprise
application.
- Author:
- Rod Johnson, Toshiaki Maki, Arjen Poutsma
- See Also:
-
Method Summary
Modifier and TypeMethodDescriptionstatic <T> Validator
forInstanceOf
(Class<T> targetClass, BiConsumer<T, Errors> delegate) Return aValidator
that checks whether the target object is an instance oftargetClass
, applying the givendelegate
to populateErrors
if it is.static <T> Validator
forType
(Class<T> targetClass, BiConsumer<T, Errors> delegate) Return aValidator
that checks whether the target object's class is identical totargetClass
, applying the givendelegate
to populateErrors
if it is.boolean
void
Validate the suppliedtarget
object, which must be of aClass
for which thesupports(Class)
method typically has (or would) returntrue
.
-
Method Details
-
supports
-
validate
Validate the suppliedtarget
object, which must be of aClass
for which thesupports(Class)
method typically has (or would) returntrue
.The supplied
errors
instance can be used to report any resulting validation errors.- Parameters:
target
- the object that is to be validatederrors
- contextual state about the validation process- See Also:
-
forInstanceOf
Return aValidator
that checks whether the target object is an instance oftargetClass
, applying the givendelegate
to populateErrors
if it is.For instance:
Validator passwordEqualsValidator = Validator.forInstanceOf(PasswordResetForm.class, (form, errors) -> { if (!Objects.equals(form.getPassword(), form.getConfirmPassword())) { errors.rejectValue("confirmPassword", "PasswordEqualsValidator.passwordResetForm.password", "password and confirm password must be same."); } });
- Type Parameters:
T
- the target object type- Parameters:
targetClass
- the class supported by the returned validatordelegate
- function invoked with the target object, if it is an instance of type T- Returns:
- the created
Validator
- Since:
- 6.1
-
forType
Return aValidator
that checks whether the target object's class is identical totargetClass
, applying the givendelegate
to populateErrors
if it is.For instance:
Validator passwordEqualsValidator = Validator.forType(PasswordResetForm.class, (form, errors) -> { if (!Objects.equals(form.getPassword(), form.getConfirmPassword())) { errors.rejectValue("confirmPassword", "PasswordEqualsValidator.passwordResetForm.password", "password and confirm password must be same."); } });
- Type Parameters:
T
- the target object type- Parameters:
targetClass
- the exact class supported by the returned validator (no subclasses)delegate
- function invoked with the target object, if it is an instance of type T- Returns:
- the created
Validator
- Since:
- 6.1
-