Comme l'a dit @Kimble, avec Jackson 2, l'utilisation du formatage par défaut est très simple ; il suffit d'enregistrer JodaModule
sur votre ObjectMapper
.
ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new JodaModule());
Pour la sérialisation/dé-sérialisation personnalisée de DateTime
vous devez mettre en œuvre votre propre StdScalarSerializer
y StdScalarDeserializer
; c'est assez alambiqué, mais peu importe.
Par exemple, voici un DateTime
sérialiseur qui utilise le ISODateFormat
avec le fuseau horaire UTC :
public class DateTimeSerializer extends StdScalarSerializer<DateTime> {
public DateTimeSerializer() {
super(DateTime.class);
}
@Override
public void serialize(DateTime dateTime,
JsonGenerator jsonGenerator,
SerializerProvider provider) throws IOException, JsonGenerationException {
String dateTimeAsString = ISODateTimeFormat.withZoneUTC().print(dateTime);
jsonGenerator.writeString(dateTimeAsString);
}
}
Et le dé-sérialiseur correspondant :
public class DateTimeDesrializer extends StdScalarDeserializer<DateTime> {
public DateTimeDesrializer() {
super(DateTime.class);
}
@Override
public DateTime deserialize(JsonParser jsonParser,
DeserializationContext deserializationContext) throws IOException, JsonProcessingException {
try {
JsonToken currentToken = jsonParser.getCurrentToken();
if (currentToken == JsonToken.VALUE_STRING) {
String dateTimeAsString = jsonParser.getText().trim();
return ISODateTimeFormat.withZoneUTC().parseDateTime(dateTimeAsString);
}
} finally {
throw deserializationContext.mappingException(getValueClass());
}
}
Puis, vous les reliez entre eux par un module :
public class DateTimeModule extends SimpleModule {
public DateTimeModule() {
super();
addSerializer(DateTime.class, new DateTimeSerializer());
addDeserializer(DateTime.class, new DateTimeDeserializer());
}
}
Ensuite, enregistrez le module sur votre ObjectMapper
:
ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new DateTimeModule());
0 votes
Les deux éléments ci-dessus devraient également fonctionner (@JsonSerialize devrait impliquer que le champ doit être sérialisé ; et le format de date devrait également s'appliquer idéalement à Joda). jira.codehaus.org/browse/JACKSON .
0 votes
Je réalise que cette question date d'il y a un certain temps, mais pour référence future, objectMapper.getSerializationConfig().setDateFormat(df) est maintenant déprécié. objectMapper.setDateFormat(df) est maintenant suggéré.
0 votes
Voir aussi stackoverflow.com/questions/27952472/