Java 8 LocalDate Jackson format
Для java.util.Дата, когда я делаю
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "dd/MM/yyyy")
private Date dateOfBirth;
затем в запросе JSON, когда я отправляю
{ {"dateOfBirth":"01/01/2000"} }
это работает.
Как я должен это сделать для поля LocalDate в Java 8??
Я пробовал использовать
@JsonDeserialize(using = LocalDateDeserializer.class)
@JsonSerialize(using = LocalDateSerializer.class)
private LocalDate dateOfBirth;
Это не сработало.
Может кто-нибудь, пожалуйста, дайте мне знать, как правильно это сделать..
Ниже приведены зависимости
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>jaxrs-api</artifactId>
<version>3.0.9.Final</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.jaxrs</groupId>
<artifactId>jackson-jaxrs-json-provider</artifactId>
<version>2.4.2</version>
</dependency>
<dependency>
<groupId>com.wordnik</groupId>
<artifactId>swagger-annotations</artifactId>
<version>1.3.10</version>
</dependency>
Переведено автоматически
Ответ 1
Я никогда не мог заставить это работать просто, используя аннотации. Чтобы заставить это работать, я создал ContextResolver
for ObjectMapper
, затем добавил JSR310Module
(обновление: теперь это JavaTimeModule
вместо), а также еще одно предостережение, заключавшееся в необходимости установить значение write-date-as-timestamp равным false . Смотрите больше в документации к модулю JSR310. Вот пример того, что я использовал.
Зависимость
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-jsr310</artifactId>
<version>2.4.0</version>
</dependency>
Примечание: Одна проблема, с которой я столкнулся, заключается в том, что в jackson-annotation
версии, подключенной к другой зависимости, использовалась версия 2.3.2, которая отменяла версию 2.4, требуемую jsr310
. Случилось так, что я получил NoClassDefFound для ObjectIdResolver
, который представляет собой класс 2.4. Итак, мне просто нужно было выстроить включенные версии зависимостей
ContextResolver
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.datatype.jsr310.JSR310Module;
import javax.ws.rs.ext.ContextResolver;
import javax.ws.rs.ext.Provider;
@Provider
public class ObjectMapperContextResolver implements ContextResolver<ObjectMapper> {
private final ObjectMapper MAPPER;
public ObjectMapperContextResolver() {
MAPPER = new ObjectMapper();
// Now you should use JavaTimeModule instead
MAPPER.registerModule(new JSR310Module());
MAPPER.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);
}
@Override
public ObjectMapper getContext(Class<?> type) {
return MAPPER;
}
}
Класс ресурсов
@Path("person")
public class LocalDateResource {
@GET
@Produces(MediaType.APPLICATION_JSON)
public Response getPerson() {
Person person = new Person();
person.birthDate = LocalDate.now();
return Response.ok(person).build();
}
@POST
@Consumes(MediaType.APPLICATION_JSON)
public Response createPerson(Person person) {
return Response.ok(
DateTimeFormatter.ISO_DATE.format(person.birthDate)).build();
}
public static class Person {
public LocalDate birthDate;
}
}
Тест
curl -v http://localhost:8080/api/person
Результат:{"birthDate":"2015-03-01"}
curl -v -POST -H "Content-Type:application/json" -d "{\"birthDate\":\"2015-03-01\"}" http://localhost:8080/api/person
Результат:2015-03-01
Смотрите также Здесь решение JAXB.
Обновить
JSR310Module
Устарел с версии 2.7 Jackson. Вместо этого вам следует зарегистрировать модуль JavaTimeModule
. Это все та же зависимость.
Ответ 2
ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new JavaTimeModule());
mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);
Ответ 3
@JsonSerialize и @JsonDeserialize у меня отлично работали. Они устраняют необходимость импортировать дополнительный модуль jsr310:
@JsonDeserialize(using = LocalDateDeserializer.class)
@JsonSerialize(using = LocalDateSerializer.class)
private LocalDate dateOfBirth;
Десериализатор:
public class LocalDateDeserializer extends StdDeserializer<LocalDate> {
private static final long serialVersionUID = 1L;
protected LocalDateDeserializer() {
super(LocalDate.class);
}
@Override
public LocalDate deserialize(JsonParser jp, DeserializationContext ctxt)
throws IOException, JsonProcessingException {
return LocalDate.parse(jp.readValueAs(String.class));
}
}
Сериализатор:
public class LocalDateSerializer extends StdSerializer<LocalDate> {
private static final long serialVersionUID = 1L;
public LocalDateSerializer(){
super(LocalDate.class);
}
@Override
public void serialize(LocalDate value, JsonGenerator gen, SerializerProvider sp) throws IOException, JsonProcessingException {
gen.writeString(value.format(DateTimeFormatter.ISO_LOCAL_DATE));
}
}
Ответ 4
В веб-приложении Spring Boot с Jackson и JSR 310 версии "2.8.5"
compile "com.fasterxml.jackson.core:jackson-databind:2.8.5"
runtime "com.fasterxml.jackson.datatype:jackson-datatype-jsr310:2.8.5"
@JsonFormat
работает:
import com.fasterxml.jackson.annotation.JsonFormat;
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd")
private LocalDate birthDate;