web-dev-qa-db-fra.com

Botte de printemps REST @RequestParam non validé

J'ai essayé plusieurs exemples sur le réseau et je ne parviens pas à faire que Spring valide mon paramètre de chaîne de requête. Il ne semble pas exécuter le REGEX/fail.

package my.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import javax.validation.Valid;
import javax.validation.constraints.Pattern;

import static org.springframework.web.bind.annotation.RequestMethod.GET;

@RestController
public class MyController {

    private static final String VALIDATION_REGEX = "^[0-9]+(,[0-9]+)*$";

    @RequestMapping(value = "/my/{id}", method = GET)
    public myResonseObject getMyParams(@PathVariable("id") String id,
                                       @Valid @Pattern(regexp = VALIDATION_REGEX) 
                                       @RequestParam(value = "myparam", required = true) String myParam) {
         // Do Stuff!
    }

}

Comportement actuel

PASS - /my/1?myparam=1
PASS - /my/1?myparam=1,2,3
PASS - /my/1?myparam=
PASS - /my/1?myparam=1,bob

Comportement souhaité

PASS - /my/1?myparam=1
PASS - /my/1?myparam=1,2,3
FAIL - /my/1?myparam=
FAIL - /my/1?myparam=1,bob

Merci

10
ptimson

Vous devez ajouter @Validated à votre classe comme ceci:

@RestController
@Validated
class Controller {
  // ...
}

METTRE À JOUR:

vous devez le configurer correctement .. ajoutez ce bean à votre contexte:

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

Exemple pour gérer une exception :

@ControllerAdvice
@Component
public class GlobalExceptionHandler {
    @ExceptionHandler
    @ResponseBody
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    public Map handle(MethodArgumentNotValidException exception) {
        return error(exception.getBindingResult().getFieldErrors()
                .stream()
                .map(FieldError::getDefaultMessage)
                .collect(Collectors.toList()));
    }


    @ExceptionHandler
    @ResponseBody
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    public Map handle(ConstraintViolationException exception) {
        return error(exception.getConstraintViolations()
                .stream()
                .map(ConstraintViolation::getMessage)
                .collect(Collectors.toList()));
    }

    private Map error(Object message) {
        return Collections.singletonMap("error", message);
    }
}
29
Jaiwo99

Tu peux essayer ça

@Pattern(regexp="^[0-9]+(,[0-9]+)*$")
private static final String VALIDATION_REGEX;

(attention au modificateur final) ou bien 

 @Pattern()
 private static final String VALIDATION_REGEX = "^[0-9]+(,[0-9]+)*$";

Puis supprimez @Pattern (regexp = VALIDATION_REGEX) de votre méthode et ne conservez que le @Valid annotation: 

public myResonseObject getMyParams(@PathVariable("id") String id, @Valid @RequestParam(value = "myparam", required = true) String myParam) {
1
georges van

Votre regex est incorrect

"^[0-9]+(,[0-9]+)*$"

Il ne sera jamais analyser

1,bob

Peut-être avez-vous besoin de:

"^\w+(,\w+)*$"

Et si vous devez également analyser une ligne vide, utilisez:

"^(\w+(,\w+)*)?$"
0
Gangnus