valider une liste de valeurs dans le printemps implique de tirer parti du cadre de validation de Spring, en utilisant spécifiquement des annotations comme @Valid
et des annotations de validation personnalisées. L'approche dépend de la nature de votre liste et des règles de validation. Si vous validez des types de données simples dans la liste (par exemple, entiers, chaînes), vous pouvez souvent compter sur des contraintes intégrées. Cependant, pour des scénarios de validation plus complexes ou une validation par rapport à un ensemble prédéfini, un validateur personnalisé est généralement nécessaire.
Une approche simple pour valider les types de données simples implique d'utiliser des annotations standard comme @NotNull
, @Size
, @Min
, @Max
, etc., directement sur le champ de la liste dans votre objet de domaine. Par exemple, si vous avez une liste d'entiers qui doivent être positifs et inférieurs à 100, vous pouvez utiliser:
public class MyObject { @NotNull @Size(min = 1, max = 10) //Example size constraint private List<@Min(0) @Max(99) Integer> myIntegerList; //Getters and setters }
Le cadre de validation de Spring appliquera automatiquement ces contraintes à chaque élément de la liste. Si un élément échoue la validation, un ConstraintViolation
correspondant sera généré.
Pour restreindre une liste pour contenir uniquement des valeurs à partir d'un ensemble prédéfini, vous aurez besoin d'un validateur personnalisé. Cela implique la création d'une annotation personnalisée et d'une classe de validatrice correspondante.
Tout d'abord, créez une annotation personnalisée:
@Constraint(validatedBy = AllowedValuesValidator.class) @Target({ElementType.FIELD, ElementType.PARAMETER}) @Retention(RetentionPolicy.RUNTIME) public @interface AllowedValues { String message() default "Invalid value in list"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; String[] values(); }
Ensuite, créez la classe de validateur:
public class AllowedValuesValidator implements ConstraintValidator<AllowedValues, List<?>> { private String[] allowedValues; @Override public void initialize(AllowedValues constraintAnnotation) { this.allowedValues = constraintAnnotation.values(); } @Override public boolean isValid(List<?> values, ConstraintValidatorContext context) { if (values == null) return true; //Consider null as valid for (Object value : values) { boolean found = false; for (String allowedValue : allowedValues) { if (value.toString().equals(allowedValue)) { found = true; break; } } if (!found) { return false; } } return true; } }
Enfin, appliquez l'annotation personnalisée à votre champ de liste:
public class MyObject { @AllowedValues(values = {"value1", "value2", "value3"}) private List<String> myStringList; //Getters and setters }
"Value3". Toute autre valeur déclenchera une erreur de validation. N'oubliez pas de gérer le potentiel myStringList
de manière appropriée, comme le montre l'exemple. NullPointerExceptions
null
Listez des valeurs dans votre validateur pour éviter NullPointerExceptions
. Déterminez si une liste null
doit être considérée comme valide ou invalide en fonction des exigences de votre application. Par exemple: BindingResult
FieldError
si vous ne l'utilisez pas déjà.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!