抱歉我的英语不好。我有像this一样的问题,但我需要Serializate。使用Retrofit将帖子发送到Android中的restfull api服务 来人帮帮我?感谢
我的问题是,如何实现自定义序列化whit gson?因为我需要序列化这个json。 whit gson。
Json是:
e.currentTarget.id
pojo是:
{
"userId": 1,
"IdEncuesta": 1,
"Resultado":
[
{
"NumeroPregunta": 1,
"TipoPregunta":1,
"Respuesta": "Pepito"
},
{
"NumeroPregunta": 2,
"TipoPregunta":2,
"Respuesta": 2
},
{
"NumeroPregunta": 3,
"TipoPregunta":3,
"ListaRespuestas":[
{
"numeroOpcion":1,
"Respuesta": 3
},
{
"numeroOpcion":2,
"Respuesta": 5
},
{
"numeroOpcion":3,
"Respuesta": 2
},
{
"numeroOpcion":4,
"Respuesta": 1
}
]
},
{
"NumeroPregunta": 4,
"TipoPregunta":4,
"ListaRespuestas":[1,3,5]
}
]
}
答案 0 :(得分:1)
{
"userId":1,
"IdEncuesta":1,
"Resultado":[
{
"NumeroPregunta":1,
"TipoPregunta":1,
"Respuesta":"Pepito"
},
{
"NumeroPregunta":2,
"TipoPregunta":2,
"Respuesta":2
},
{
"NumeroPregunta":3,
"TipoPregunta":3,
"ListaRespuestas":[ //ListaRespuestas has a relational object, ok
{
"numeroOpcion":1,
"Respuesta":3
},
{
"numeroOpcion":2,
"Respuesta":5
},
{
"numeroOpcion":3,
"Respuesta":2
},
{
"numeroOpcion":4,
"Respuesta":1
}
]
},
{
"NumeroPregunta":4,
"TipoPregunta":4,
"ListaRespuestas":[ //ListaRespuestas don't have a relational object, where is it ?
1,
3,
5
]
}
]
}
这导致了JSON语法异常,我不知道这是不是你的问题,但我发现的错误就是这个。
答案 1 :(得分:0)
我想比我的更好的解决方案..
我在这里做的是ListaRespuestas
我将检查第一项JsonObject
或Integer/Premitive
并根据我正在读数据。
try {
RespuestaEncuesta t = gson.fromJson(json, RespuestaEncuesta.class);
for (RespuestaEncuesta.Resultado item : t.Resultado) {
if (item.ListaRespuestas != null) {
JsonElement element = item.ListaRespuestas.get(0);
if (element.isJsonObject()) {//check element/item is JsonObject or Integer
for (int i = 0; i < item.ListaRespuestas.size(); i++) {
JsonObject object = (JsonObject) item.ListaRespuestas.get(i);
//System.out.print(" J Object " + object.get("numeroOpcion").getAsString());
}
} else {
//System.out.println("Json Primitive");
for (int i = 0; i < item.ListaRespuestas.size(); i++) {
JsonPrimitive object = (JsonPrimitive) item.ListaRespuestas.get(i);
//System.out.print(" J Integer " + object.getAsInt());
}
}
}
}
} catch (JsonSyntaxException | JsonIOException | FileNotFoundException e) {
e.printStackTrace();
}