it-swarm.com.de

Jackson deserialisiert JSON mit einem Zeitstempelfeld

Ich habe eine solche Zeichenfolge:

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

Ich versuche, auf diese Weise etwas zu erreichen:

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

Und MyObject-Klasse:

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

Ich habe eine solche Ausnahme:

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"}; 

Ich verstehe nicht warum ... Wenn ich im Debug-Modus Timestamp.valueOf () mit "2017-04-12 17: 04: 42.896026" verwende - ich habe Erfolg

6
Kiril Mytsykov

Ich denke, Sie müssen das erwartete Datums-/Zeitformat mit der @JsonFormat-Annotation wie unten gezeigt einstellen.

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

Sie können die Zeitzone auch als @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss.SSS",timezone="PST") einstellen.

17
Justin Jose

Holen Sie sich zunächst Zeitstempel als Zeichenfolge und konvertieren Sie sie in den gewünschten Zeitstempel.

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

konvertieren Sie die Zeichenfolge mithilfe des folgenden Codes in das gewünschte Zeitstempelformat

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

Der Wert, den Sie im Debug-Modus sehen, ist "toString ()" - Version des tatsächlichen Werts des Zeitstempels. Verlassen Sie sich also nicht auf das, was Sie im Debug-Modus prüfen. Sie können die @JsonFormat-Annotation verwenden, mit der Sie Ihren Zeitstempel mit dem angegebenen Format konvertieren können. Sie müssen auch beim Konvertieren auf die Zeitzonen achten!

0
adi