Frühjahr + Jackson + joda time: so legen Sie die Serialisierung/Deserialisierung-format?

Habe ich die folgende Klasse:

public static class ARestRequestParam
{
    String name;
    LocalDate date;  //joda type
}

Und ich will es deserialisiert werden aus der folgenden JSON, die verarbeitet wird, durch jackson.

{ name:"abc", Datum:"20131217" }

Eigentlich will ich zu Deserialisieren alle LocalDate Feld in einer Klasse mit "JJJJMMTT" - format, ohne duplizieren der format-string ohne jede setter-Methode, ohne XML-Konfiguration. (Das ist, Beschriftungs-und Java-code ist besser)
Wie kann es getan werden?

Auch, ich auch wollen zu wissen die Serialisierung Teil. das ist, LocalDate -> "JJJJMMTT".

Gesehen hab ich Folgendes:

Aber ich weiß nicht, was anwendbar ist, und die meisten up-to-date.

BTW, ich benutze Spring Boot.

UPDATE

Ok, ich habe es geschafft, zu schreiben funktionierenden code für die Deserialisierung Teil.
Es ist wie folgt:

@Configuration
@EnableWebMvc
public class WebMvcConfiguration extends WebMvcConfigurerAdapter
{
@Override
public void configureMessageConverters(
List<HttpMessageConverter<?>> converters)
{
converters.add(jacksonConverter());
}
@Bean
public MappingJackson2HttpMessageConverter jacksonConverter()
{
MappingJackson2HttpMessageConverter converter =
new MappingJackson2HttpMessageConverter();
ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new ApiJodaModule());
converter.setObjectMapper(mapper);
return converter;
}
@SuppressWarnings("serial")
private class ApiJodaModule extends SimpleModule
{
public ApiJodaModule()
{
addDeserializer(LocalDate.class, new ApiLocalDateDeserializer());
}
}
@SuppressWarnings("serial")
private static class ApiLocalDateDeserializer
extends StdScalarDeserializer<LocalDate>
{
private static DateTimeFormatter formatter =
DateTimeFormat.forPattern("yyyyMMdd");
public ApiLocalDateDeserializer() { super(LocalDate.class); }
@Override
public LocalDate deserialize(JsonParser jp, DeserializationContext ctxt)
throws IOException, JsonProcessingException
{
if (jp.getCurrentToken() == JsonToken.VALUE_STRING)
{
String s = jp.getText().trim();
if (s.length() == 0)
return null;
return LocalDate.parse(s, formatter);
}
throw ctxt.wrongTokenException(jp, JsonToken.NOT_AVAILABLE,
"expected JSON Array, String or Number");
}
}
}

Ich hatte zur Umsetzung der deserializer mich, da die datetime-format für die deserializer, die im jackson-datatype-joda nicht verändert werden kann. So, da habe ich umgesetzt deserializer mich, jackson-datatype-joda ist nicht erforderlich. (obwohl ich kopiert habe Teile des Codes)

Ist dieser code Ok?

Ist dieser up-to-date-Lösung?

Gibt es einen anderen einfacheren Weg?

Jeder Vorschlag wäre sehr dankbar.

UPDATE

Folgenden Dave Syer Vorschlag, modifizierte ich die Quelle oben wie folgt:

Entfernt 2 Methoden: configureMessageConverters(), jacksonConverter()

Hinzugefügt folgende Methode in WebMvcConfiguration-Klasse:

@Bean
public Module apiJodaModule()
{
return new ApiJodaModule();
}

Aber jetzt funktioniert es nicht. Es scheint apiJodaModule() wird ignoriert.

Wie kann ich machen, damit es funktioniert?

(Es scheint, dass ich nicht haben sollte eine Klasse, die hat @EnableWebMvc, diese Funktion zu verwenden.)

Die version, die ich benutze, ist org.springframework.boot:spring-boot-starter-web:0.5.0.M6.

UPDATE

Letzte funktionierende version ist wie folgt: (mit anderen Konfigurationen, die ich bisher gemacht haben in der Klasse, die hatte @EnableWebMvc)

Wie Dave Syer erwähnt, funktioniert das nur auf BUILD-SNAPSHOT-version, zumindest für jetzt.

@Configuration
public class WebMvcConfiguration
{
@Bean
public WebMvcConfigurerAdapter apiWebMvcConfiguration()
{
return new ApiWebMvcConfiguration();
}
@Bean
public UserInterceptor userInterceptor()
{
return new UserInterceptor();
}
public class ApiWebMvcConfiguration extends WebMvcConfigurerAdapter
{
@Override
public void addInterceptors(InterceptorRegistry registry)
{
registry.addInterceptor(userInterceptor())
.addPathPatterns("/api/user/**");
}
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry)
{
registry.addResourceHandler("/**")
.addResourceLocations("/")
.setCachePeriod(0);
}
}
@Bean
public Module apiJodaModule()
{
return new ApiJodaModule();
}
@SuppressWarnings("serial")
private static class ApiJodaModule extends SimpleModule
{
public ApiJodaModule()
{
addDeserializer(LocalDate.class, new ApiLocalDateDeserializer());
}
private static final class ApiLocalDateDeserializer
extends StdScalarDeserializer<LocalDate>
{
public ApiLocalDateDeserializer() { super(LocalDate.class); }
@Override
public LocalDate deserialize(JsonParser jp,
DeserializationContext ctxt)
throws IOException, JsonProcessingException
{
if (jp.getCurrentToken() == JsonToken.VALUE_STRING)
{
String s = jp.getText().trim();
if (s.length() == 0)
return null;
return LocalDate.parse(s, localDateFormatter);
}
throw ctxt.mappingException(LocalDate.class);
}
}
private static DateTimeFormatter localDateFormatter =
DateTimeFormat.forPattern("yyyyMMdd");
}
}
InformationsquelleAutor zeodtr | 2013-12-18
Schreibe einen Kommentar