Как заставить jettison писать массив, даже если в массиве есть только один элемент?
С упрощенным примером ниже:
Я получаю следующее, как ожидалось:
{"person":{"name":"john","tags":["tag1","tag2"]}}
Однако, если я устанавливаю только один тег, я получаю следующее:
{"person":{"name":"john","tags":"tag1"}}
И я ожидал получить это:
{"person":{"name":"john","tags":["tag1"]}}
То есть, jettison удалил массив для тегов, потому что в массиве есть только один элемент.
Я думаю, что это довольно опасно.
Как заставить jettison писать массив, даже если есть только один элемент?
Примечание. Я знаю, что есть другие альтернативы сбрасыванию, такие как StAXON.
Однако здесь я спрашиваю, как добиться этого, используя Jettison.
Пожалуйста, не предлагайте другую альтернативу выбросу.
import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.*;
import java.io.*;
import javax.xml.bind.*;
import javax.xml.stream.XMLStreamWriter;
import org.codehaus.jettison.mapped.*;
public class JettisonTest {
public static void main(String[] args) throws Exception {
JAXBContext jc = JAXBContext.newInstance(Person.class);
Person person = new Person();
person.name = "john";
person.tags.add("tag1");
person.tags.add("tag2");
Configuration config = new Configuration();
MappedNamespaceConvention con = new MappedNamespaceConvention(config);
Writer writer = new OutputStreamWriter(System.out);
XMLStreamWriter xmlStreamWriter = new MappedXMLStreamWriter(con, writer);
Marshaller marshaller = jc.createMarshaller();
marshaller.marshal(person, xmlStreamWriter);
}
}
@XmlRootElement
@XmlAccessorType(XmlAccessType.FIELD)
class Person {
String name;
List<String> tags = new ArrayList<String>();
}
Ответы
Ответ 1
Я нашел это: https://blogs.oracle.com/japod/entry/missing_brackets_at_json_one
Кажется, что добавление строки в ваш контекстный resolver для явного указания, что tags
является массивом, является способом сделать это; т.е.
props.put(JSONJAXBContext.JSON_ARRAYS, "[\\"tags\\"]");
NB: Я не знаком с компанией Jettison, поэтому у меня нет личного опыта, чтобы поддержать это; только информация в вышеупомянутом сообщении в блоге.
@Provider
public class JAXBContextResolver implements ContextResolver<JAXBContext> {
private JAXBContext context;
private Class[] types = {ArrayWrapper.class};
public JAXBContextResolver() throws Exception {
Map props = new HashMap<String, Object>();
props.put(JSONJAXBContext.JSON_NOTATION, "MAPPED");
props.put(JSONJAXBContext.JSON_ROOT_UNWRAPPING, Boolean.TRUE);
props.put(JSONJAXBContext.JSON_ARRAYS, "[\\"tags\\"]"); //STATE WHICH ELEMENT IS AN ARRAY
this.context = new JSONJAXBContext(types, props);
}
public JAXBContext getContext(Class<?> objectType) {
return (types[0].equals(objectType)) ? context : null;
}
}