web-dev-qa-db-fra.com

Validation @PathVariable au printemps 4

Comment puis-je valider ma variable de chemin au printemps? Je veux valider le champ id, car son seul champ ne me permet pas de passer à un Pojo

@RestController
public class MyController {
    @RequestMapping(value = "/{id}", method = RequestMethod.PUT)
    public ResponseEntity method_name(@PathVariable String id) {
        /// Some code
    }
}

J'ai essayé de faire l'ajout de validation à la variable de chemin mais cela ne fonctionne toujours pas

    @RestController
    @Validated
public class MyController {
    @RequestMapping(value = "/{id}", method = RequestMethod.PUT)
    public ResponseEntity method_name(
            @Valid 
            @Nonnull  
            @Size(max = 2, min = 1, message = "name should have between 1 and 10 characters") 
            @PathVariable String id) {
    /// Some code
    }
}
10
R.A.S.

Vous devez créer un bean dans votre configuration Spring:

 @Bean
    public MethodValidationPostProcessor methodValidationPostProcessor() {
         return new MethodValidationPostProcessor();
    }

Vous devriez laisser l'annotation @Validated sur votre contrôleur. 

Et vous avez besoin d’un gestionnaire d’exception dans votre classe MyController pour gérer la ConstraintViolationException:

@ExceptionHandler(value = { ConstraintViolationException.class })
    @ResponseStatus(value = HttpStatus.BAD_REQUEST)
    public String handleResourceNotFoundException(ConstraintViolationException e) {
         Set<ConstraintViolation<?>> violations = e.getConstraintViolations();
         StringBuilder strBuilder = new StringBuilder();
         for (ConstraintViolation<?> violation : violations ) {
              strBuilder.append(violation.getMessage() + "\n");
         }
         return strBuilder.toString();
    }

Après ces modifications, vous devriez voir votre message lorsque la validation aboutit.

P.S .: Je viens de l'essayer avec votre validation @Size.

16
Patrick

Pour archiver cet objectif, j'ai appliqué cette solution de contournement pour obtenir un message de réponse égal à un réel Validator:

@GetMapping("/check/email/{email:" + Constants.LOGIN_REGEX + "}")
@Timed
public ResponseEntity isValidEmail(@Email @PathVariable(value = "email") String email) {
    return userService.getUserByEmail(email).map(user -> {
        Problem problem = Problem.builder()
            .withType(ErrorConstants.CONSTRAINT_VIOLATION_TYPE)
            .withTitle("Method argument not valid")
            .withStatus(Status.BAD_REQUEST)
            .with("message", ErrorConstants.ERR_VALIDATION)
            .with("fieldErrors", Arrays.asList(new FieldErrorVM("", "isValidEmail.email", "not unique")))
            .build();
        return new ResponseEntity(problem, HttpStatus.BAD_REQUEST);
    }).orElse(
        new ResponseEntity(new UtilsValidatorResponse(EMAIL_VALIDA), HttpStatus.OK)
    );
}
0
Manuel Spigolon