144 votes

Comment accepter les paramètres de date dans une requête GET vers le contrôleur MVC de Spring ?

J'ai une requête GET qui envoie une date au format AAAA-MM-JJ à un contrôleur Spring. Le code du contrôleur est le suivant :

@RequestMapping(value="/fetch" , method=RequestMethod.GET)
    public @ResponseBody String fetchResult(@RequestParam("from") Date fromDate) {
        //Content goes here
    }

La demande est envoyée correctement comme je le vérifie avec Firebug. Je reçois l'erreur :

Statut HTTP 400 : la demande envoyée par le client est syntaxiquement incorrecte.

Comment puis-je faire en sorte que le contrôleur accepte ce format de date ? Veuillez m'aider. Qu'est-ce que je fais de mal ?

282voto

LittleLebowski Points 955

Ok, je l'ai résolu. Je l'écris pour tous ceux qui pourraient être fatigués après une journée entière de codage non-stop et manquer une chose aussi stupide.

@RequestMapping(value="/fetch" , method=RequestMethod.GET)
    public @ResponseBody String fetchResult(@RequestParam("from") @DateTimeFormat(pattern="yyyy-MM-dd") Date fromDate) {
        //Content goes here
    }

Oui, c'est simple. Il suffit d'ajouter l'annotation DateTimeFormat.

14voto

AbdusSalam Points 111

Voici ce que j'ai fait pour obtenir une date formatée à partir du front-end

  @RequestMapping(value = "/{dateString}", method = RequestMethod.GET)
  @ResponseBody
  public HttpStatus getSomething(@PathVariable @DateTimeFormat(iso = DateTimeFormat.ISO.DATE) String dateString) {
   return OK;
  }

Vous pouvez l'utiliser pour obtenir ce que vous voulez.

14voto

Paul T Points 8

... ou vous pouvez le faire de la bonne manière et avoir une règle cohérente pour la sérialisation/désérialisation des dates dans toute votre application. mettez ceci dans application.properties :

spring.mvc.date-format=yyyy-MM-dd

7voto

Aman Goel Points 1457

La solution ci-dessous fonctionne parfaitement pour l'application Spring Boot.

Contrôleur :

@GetMapping("user/getAllInactiveUsers")
List<User> getAllInactiveUsers(@RequestParam("date") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") Date dateTime) {
    return userRepository.getAllInactiveUsers(dateTime);
}

Ainsi, dans l'appelant (dans mon cas, il s'agit d'un flux web), nous devons passer la date et l'heure de cette manière( "aaaa-MM-jj HH:mm:ss" ).

Côté appelant :

public Flux<UserDto> getAllInactiveUsers(String dateTime) {
    Flux<UserDto> userDto = RegistryDBService.getDbWebClient(dbServiceUrl).get()
            .uri("/user/getAllInactiveUsers?date={dateTime}", dateTime).retrieve()
            .bodyToFlux(User.class).map(UserDto::of);
    return userDto;
}

Dépôt :

@Query("SELECT u from User u  where u.validLoginDate < ?1 AND u.invalidLoginDate < ?1 and u.status!='LOCKED'")
List<User> getAllInactiveUsers(Date dateTime);

Santé !

4voto

David Jesus Points 1031

Si vous voulez utiliser une PathVariable, vous pouvez utiliser une méthode d'exemple ci-dessous (toutes les méthodes sont et font la même chose) :

//You can consume the path .../users/added-since1/2019-04-25
@GetMapping("/users/added-since1/{since}")
public String userAddedSince1(@PathVariable("since") @DateTimeFormat(pattern = "yyyy-MM-dd") Date since) {
    return "Date: " + since.toString(); //The output is "Date: Thu Apr 25 00:00:00 COT 2019"
}

//You can consume the path .../users/added-since2/2019-04-25
@RequestMapping("/users/added-since2/{since}")
public String userAddedSince2(@PathVariable("since") @DateTimeFormat(iso = DateTimeFormat.ISO.DATE) Date since) {
    return "Date: " + since.toString(); //The output is "Date: Wed Apr 24 19:00:00 COT 2019"
}

//You can consume the path .../users/added-since3/2019-04-25
@RequestMapping("/users/added-since3/{since}")
public String userAddedSince3(@PathVariable("since") @DateTimeFormat(pattern = "yyyy-MM-dd") Date since) {
    return "Date: " + since.toString(); //The output is "Date: Thu Apr 25 00:00:00 COT 2019"
}

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X