I need to create a json response for a report. Something like this:
var data = [
["", "Kia", "Nissan", "Toyota", "Honda"],
["2008", 10, 11, 12, 13],
["2009", 20, 11, 14, 13],
["2010", 30, 15, 12, 13]
];
Im using jackson library and i create a JsonGenerator, this is the code i have:
String[] cols = new String[5]; //Number of report columns
JsonFactory jfactory = new JsonFactory();
JsonGenerator jGenerator = jfactory.createJsonGenerator(response.getOutputStream(),JsonEncoding.UTF8);
jGenerator.writeStartArray();
jGenerator.writeStartArray();
jGenerator.writeStringField(cols[0], "");
//until...
jGenerator.writeStringField(cols[4], "Honda");
jGenerator.writeEndArray();
jGenerator.writeStartArray();
jGenerator.writeStringField(cols[0], "2008");
//until...
jGenerator.writeStringField(cols[4], "13");
jGenerator.writeEndArray();
//and the same with the next rows...
jGenerator.writeEndArray();
The problem is when setting the first value i get this error:
org.codehaus.jackson.JsonGenerationException: Can not write a field name, expecting a value
writeXXXField()to write array elements because array elements are not fields but simple values, use methods that output simple values likewriteNumber()orwriteString().