我在从第三方解析json时遇到了一些问题。
"field_head_picture":{
"und":[
{
"fid":"11917",
"uid":"1",
"filename":"fr_bril_id_promo.jpg",
"uri":"public://fr_bril_id_promo.jpg",
"filemime":"image/jpeg",
"filesize":"12744",
"status":"1",
"timestamp":"1429724219",
"uuid":"bb8c1a73-451c-4e17-9001-146c6e06f255",
"display":"1",
"description":""
}
]
}
有时它会回来
"field_head_picture":[
],
如您所见,它返回一个对象或一个空数组。我知道这是一个糟糕的json设计,但我不能改变它。
所以我写了一个类型适配器
FieldHeadPictureTypeAdapter headPictureTypeAdapter = new FieldHeadPictureTypeAdapter();
return new GsonBuilder()
.registerTypeAdapter(FieldHeadPicture.class, headPictureTypeAdapter)
.create();
这是我的打字机适配器
public class FieldHeadPictureTypeAdapter extends TypeAdapter<FieldHeadPicture> {
private Gson gson = new Gson();
@Override
public void write(JsonWriter out, FieldHeadPicture value) throws IOException {
gson.toJson(value, FieldHeadPicture.class, out);
}
@Override
public FieldHeadPicture read(JsonReader jsonReader) throws IOException {
try {
JsonToken peek = jsonReader.peek();
if (peek == JsonToken.BEGIN_ARRAY) {
jsonReader.beginArray();
jsonReader.endArray();
return new FieldHeadPicture();
} else if (peek == JsonToken.BEGIN_OBJECT) {
jsonReader.beginObject();
FieldHeadPicture picture = new Gson().fromJson(jsonReader.nextString(), FieldHeadPicture.class);
jsonReader.endObject();
return picture;
}
} catch (Exception e) {
return new FieldHeadPicture();
}
return new FieldHeadPicture();
}
如果数组为空,我只想返回一个空的fieldheadpicture,否则解析为fieldheadpicture对象。
但我犯了个错误
java.lang.IllegalStateException:应为字符串,但在第1行第622列path$.field_head_picture处为name。
这是我的野外头像课
public class FieldHeadPicture {
@SerializedName("und")
private List<Und> und;
public List<Und> getListFieldAdditionalPicture() {
return und;
}
public FieldHeadPicture() {
}
}
最佳答案
我认为您不想在nextString()
上调用JsonReader
,而是直接反序列化包含的对象,使用您已经创建的gson实例而不是新实例。换言之,else子句变得简单:
} else if (peek == JsonToken.BEGIN_OBJECT) {
return gson.fromJson(jsonReader, FieldHeadPicture.class);
}
也不需要用这种方式。如果不起作用,请告诉我,我可以为您发布一个测试用例。