web-dev-qa-db-de.com

@PathVariable-Validierung im Frühling 4

Wie kann ich meine Pfadvariable im Frühjahr überprüfen? Ich möchte das ID-Feld bestätigen, da es nur ein einziges Feld ist, das ich nicht in ein Pojo verschieben möchte

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

Ich habe versucht, die Pfadvariable zu validieren, aber sie funktioniert immer noch nicht

    @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.

Sie müssen eine Bean in Ihrer Spring-Konfiguration erstellen:

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

Sie sollten die Annotation @Validated auf Ihrem Controller belassen. 

Und Sie benötigen einen Exceptionhandler in Ihrer MyController-Klasse, um dieConstraintViolationException zu handhaben:

@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();
    }

Nach diesen Änderungen sollten Sie Ihre Nachricht sehen, wenn die Validierung erfolgreich ist.

P .: Ich habe es gerade mit Ihrer @Size-Validierung ausprobiert.

16
Patrick

Um dieses Ziel zu archivieren, habe ich diese Problemumgehung angewendet, um eine Antwortnachricht zu erhalten, die einer echten Validator entspricht:

@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