Конечно, существует автоматизированный способ, называемый сериализацией и десериализацией, и вы можете определить его с помощью специальных аннотаций ( @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).