sto lottando con questo:Spring MVC + Jackson + Guava multimap
abbiamo una classe da tavolo con un multimap Guava (codice semplificato, in fondo 1 membro, 2 costruttori, getter e setter per la multimap):
E voglio serializzare questo utilizzando Spring MVC 3.2.11 utilizzando jackson 2.4.3.
POM dipendenze rilevanti sono:
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.4.3</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.4.3</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-guava</artifactId>
<version>2.4.3</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.2.11.RELEASE</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>3.2.11.RELEASE</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
mio spring.xml SOCIETÀ si presenta così (segue questo example)
<bean id="abstractJacksonObjectMapper"
class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"
p:targetMethod="registerModule">
<property name="targetObject">
<bean class="org.springframework.http.converter.json.Jackson2ObjectMapperFactoryBean"
p:indentOutput="true">
<!--<property name="featuresToDisable">-->
<!--<util:constant static-field="com.fasterxml.jackson.databind.DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES" />-->
<!--</property>-->
</bean>
</property>
<property name="arguments">
<list>
<bean class="com.fasterxml.jackson.datatype.guava.GuavaModule" />
</list>
</property>
</bean>
<bean id="abstractMappingJacksonHttpMessageConverter"
class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"
abstract="true"/>
<bean id="abstractMappingJacksonJsonView"
class="org.springframework.web.servlet.view.json.MappingJackson2JsonView"
abstract="true"
p:extractValueFromSingleKeyModel="true"/>
<bean id="jacksonObjectMapper" parent="abstractJacksonObjectMapper" />
<bean id="mappingJacksonHttpMessageConverter"
parent="abstractMappingJacksonHttpMessageConverter"
p:objectMapper-ref="jacksonObjectMapper"
p:supportedMediaTypes="application/json" />
<bean id="mappingJacksonJsonView"
parent="abstractMappingJacksonJsonView"
p:objectMapper-ref="jacksonObjectMapper"
p:contentType="application/json" />
ho anche provato questo altro approccio utilizzando un Jackson2ObjectMapperFactoryBean esteso:
<!-- Json rendering configuration-->
<bean class="org.springframework.web.servlet.view.ContentNegotiatingViewResolver">
<property name="order" value="1" />
<property name="mediaTypes">
<map>
<entry key="json" value="application/json" />
<entry key="xml" value="application/xml" />
</map>
</property>
<property name="defaultViews">
<list>
<bean class="org.springframework.web.servlet.view.json.MappingJackson2JsonView">
<property name="objectMapper">
<bean class="my.package.Jackson2ObjectMapperFactoryBean"/>
</property>
</bean>
</list>
</property>
<property name="ignoreAcceptHeader" value="true" />
</bean>
E poi la FactoryBean assomiglia a questo:
package my.package;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.datatype.guava.GuavaModule;
public class Jackson2ObjectMapperFactoryBean extends org.springframework.http.converter.json.Jackson2ObjectMapperFactoryBean{
public ObjectMapper getObject(){
ObjectMapper objectMapper =super.getObject();
objectMapper.registerModule(new GuavaModule());
return objectMapper;
}
}
ho una classe di prova che funziona bene e non sta usando Primavera a tutti (solo test Table.class + Jackson + guava) semplificato:
Table study = getTable();
ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new GuavaModule());
String tableString = mapper.writeValueAsString(table);
E serialises in modo corretto:
{
"fields":{
"Field1":[
{
"index":0,
"header":"Field1",
"fieldType":"fieldtype",
"description":null,
"cleanHeader":null
}
],
"Field2":[
{
"index":1,
"header":"Field2",
"fieldType":"fieldtype",
"description":null,
"cleanHeader":null
}
]
}
}
Utilizzando primavera (uno qualsiasi dei 2 approcci) sto ottenendo:
{
"fields":{
"empty": false
}
}
mio controller ha un'annotazione @ResponseBody ed è il ritorno di una tabella.
CURA: Sto debug in profondità in classi primavera (tempo di abeti, ;-)) e org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyMethodProcessor sta gestendo la richiesta. Questo è legato al mio problema ... Il mio xml di primavera è in qualche modo in contraddizione con l'annotazione @ResponseBody?
Qualche idea su cosa sto facendo male?
NOTA: Ho bisogno del Multimap, non può essere una raccolta Java standard.
Grazie Katerina! Ho aggiunto il tuo codice e provato con entrambi gli approcci di cui sopra .... Sto ottenendo gli stessi "campi": {"vuoto": falso} risultato. – Pablo