Pracuję nad projektem, który używa oprogramowania Jersey do konwersji obiektów na JSON. Chciałbym, aby móc pisać zagnieżdżonych list tak:Jak mogę zagnieżdżać listy zagnieżdżone jako JSON przy użyciu Jersey? Otrzymuję tablicę wartości null lub tablicę jednoskładnikowych słowników zawierających tablicę
{"data":[["one", "two", "three"], ["a", "b", "c"]]}
Przedmiotem Chciałbym przekonwertować pierwszy reprezentował dane jako < LinkedList LinkedList < <String> > > i wyobraziłem Jersey po prostu postąpiłby słusznie. Powyższe było wyjście w postaci listy null:
{"data":[null, null]}
Po przeczytaniu że zagnieżdżone obiekty muszą być opakowane, próbowałem następujące:
@XmlRootElement(name = "foo")
@XmlType(propOrder = {"data"})
public class Foo
{
private Collection<FooData> data = new LinkedList<FooData>();
@XmlElement(name = "data")
public Collection<FooData> getData()
{
return data;
}
public void addData(Collection data)
{
FooData d = new FooData();
for(Object o: data)
{
d.getData().add(o == null ? (String)o : o.toString());
}
this.data.add(d);
}
@XmlRootElement(name = "FooData")
public static class FooData
{
private Collection<String> data = new LinkedList<String>();
@XmlElement
public Collection<String> getData()
{
return data;
}
}
}
Ten kod wyjścia, co poniżej, który jest bliżej do tego, co Chcę:
{"data":[{"data":["one", "two", "three"]},{"data":["a", "b", "c"]}]}
Chcę pierwsze dane się lista list, nie lista słowników jednoelementowych. Jak to osiągnąć?
Oto mój JAXBContentResolver:
@Provider
public class JAXBContextResolver implements ContextResolver<JAXBContext>
{
private JAXBContext context;
private Set<Class<?>> types;
// Only parent classes are required here. Nested classes are implicit.
protected Class<?>[] classTypes = new Class[] {Foo.class};
protected Set<String> jsonArray = new HashSet<String>(1) {
{
add("data");
}
};
public JAXBContextResolver() throws Exception
{
Map<String, Object> props = new HashMap<String, Object>();
props.put(JSONJAXBContext.JSON_NOTATION, JSONJAXBContext.JSONNotation.MAPPED);
props.put(JSONJAXBContext.JSON_ROOT_UNWRAPPING, Boolean.TRUE);
props.put(JSONJAXBContext.JSON_ARRAYS, jsonArray);
this.types = new HashSet<Class<?>>(Arrays.asList(classTypes));
this.context = new JSONJAXBContext(classTyes, props);
}
public JAXBContext getContext(Class<?> objectType)
{
return (types.contains(objectType)) ? context : null;
}
}
Ok, właśnie pomyślałem, że twoja sprawa była bardziej skomplikowana niż ja ... – Arnaudweb