web-dev-qa-db-fra.com

Jackson désérialise JSON avec un champ d'horodatage

J'ai une telle ficelle:

{
   "debug":"false", 
   "switchTime":"2017-04-12 17:04:42.896026"
}

J'essaie d'obtenir un objet dans une telle approche:

new ObjectMapper().readValue(string, MyObject.class);

Et la classe MyObject:

class MyObject {
    private Boolean debug;
    private Timestamp switchTime;
    //...getters, setters, constructors
}

J'ai une telle exception:

com.fasterxml.jackson.databind.exc.InvalidFormatException: 
Can not deserialize value of type Java.sql.Timestamp from String
"2017-04-12 17:04:42.896026": not a valid representation (error:
Failed to parse Date value '2017-04-12 17:04:42.896026': 
Can not parse date "2017-04-12 17:04:42.896026Z": while it seems 
to fit format 'yyyy-MM-dd'T'HH:mm:ss.SSS'Z'', 
parsing fails (leniency? null))  at [Source:   
{"debug":"false", "switchTime":"2017-04-12 17:04:42.896026"}; 

Je ne comprends pas pourquoi ... Si j'utilise en mode débogage Timestamp.valueOf () avec "2017-04-12 17: 04: 42.896026" - j'ai du succès

6
Kiril Mytsykov

Je pense que vous devez définir le format de date/heure prévu à l'aide de l'annotation @JsonFormat comme indiqué ci-dessous.

class MyObject {
  private Boolean debug;
  @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss.SSS")
  private Timestamp switchTime;
  //...getters, setters, constructors
}

Vous pouvez également définir le fuseau horaire comme @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss.SSS",timezone="PST")

17
Justin Jose

Commencez par obtenir l’horodatage sous forme de chaîne, puis convertissez-le en modèle d’horodatage souhaité.

class MyObject {
  private Boolean debug;
  private String switchTime;
  //...getters, setters, constructors
}

convertir une chaîne au format d'horodatage souhaité à l'aide du code suivant

try{
    SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss.SSS");
    Date parsedDate = dateFormat.parse(switchTime);
    Timestamp timestamp = new Java.sql.Timestamp(parsedDate.getTime());
    }catch(Exception e){
    }
1
Pranay Kumbhalkar

La valeur que vous voyez en mode débogage est la version "toString ()" de la valeur réelle de timestamp. Par conséquent, ne vous fiez pas à ce que vous inspectez en mode débogage. Vous pouvez utiliser l'annotation @JsonFormat pour vous aider à convertir votre horodatage au format spécifié. Vous devez également prendre en compte les fuseaux horaires lors de la conversion!

0
adi