Звичайно, існує автоматизований спосіб, який називається серіалізацією та десеріалізацією, і ви можете визначити це за допомогою конкретних анотацій ( @JsonSerialize , @JsonDeserialize ), як згадує також pb2q.
Ви можете використовувати як java.util.Date, так і java.util.Calendar ... і, можливо, також JodaTime.
Анотації @JsonFormat не спрацювали для мене так, як я хотів (він налаштував часовий пояс на інше значення) під час десеріалізації (серіалізація спрацювала ідеально):
@JsonFormat(locale = "hu", shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm", timezone = "CET")
@JsonFormat(locale = "hu", shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm", timezone = "Europe/Budapest")
Вам потрібно використовувати спеціальний серіалізатор та спеціальний десеріалізатор замість анотації @JsonFormat, якщо ви хочете передбачити результат. Тут я знайшов справжній хороший підручник та рішення http://www.baeldung.com/jackson-serialize-dates
Є приклади для полів Дата, але мені потрібні поля Календаря, ось ось моя реалізація :
Клас серіалізатора :
public class CustomCalendarSerializer extends JsonSerializer<Calendar> {
public static final SimpleDateFormat FORMATTER = new SimpleDateFormat("yyyy-MM-dd HH:mm");
public static final Locale LOCALE_HUNGARIAN = new Locale("hu", "HU");
public static final TimeZone LOCAL_TIME_ZONE = TimeZone.getTimeZone("Europe/Budapest");
@Override
public void serialize(Calendar value, JsonGenerator gen, SerializerProvider arg2)
throws IOException, JsonProcessingException {
if (value == null) {
gen.writeNull();
} else {
gen.writeString(FORMATTER.format(value.getTime()));
}
}
}
Клас десаріалізатора :
public class CustomCalendarDeserializer extends JsonDeserializer<Calendar> {
@Override
public Calendar deserialize(JsonParser jsonparser, DeserializationContext context)
throws IOException, JsonProcessingException {
String dateAsString = jsonparser.getText();
try {
Date date = CustomCalendarSerializer.FORMATTER.parse(dateAsString);
Calendar calendar = Calendar.getInstance(
CustomCalendarSerializer.LOCAL_TIME_ZONE,
CustomCalendarSerializer.LOCALE_HUNGARIAN
);
calendar.setTime(date);
return calendar;
} catch (ParseException e) {
throw new RuntimeException(e);
}
}
}
та використання вищевказаних класів:
public class CalendarEntry {
@JsonSerialize(using = CustomCalendarSerializer.class)
@JsonDeserialize(using = CustomCalendarDeserializer.class)
private Calendar calendar;
// ... additional things ...
}
Використовуючи цю реалізацію, процес серіалізації та десеріалізації послідовно призводить до початкового значення.
Тільки використовуючи анотацію @JsonFormat, деріаріалізація дає різний результат. Я думаю, що через встановлення за замовчуванням внутрішньої бібліотеки бібліотеки те, що ви не можете змінити за допомогою параметрів анотації (такий був і мій досвід роботи з бібліотекою Jackson 2.5.3 та 2.6.3).