我在这里有一个复杂的json
我正在尝试在我的模型类“ ChromeJsonModel”中映射它,例如:
Type collectionType = new TypeToken<List<ChromeJsonModel>>(){}.getType();
List<ChromeJsonModel> jsonModelList = (List<ChromeJsonModel>) new Gson().fromJson( jsonPrettyPrintString , collectionType);
但是我收到以下错误。
Expected BEGIN_ARRAY but was BEGIN_OBJECT
我为什么会在哪里出问题?
您拥有非常复杂的JSON
有效负载,其中相同的属性可能具有一个JSON object
或JSON array
多个对象。Gson
默认情况下不会处理这种情况,因此我们需要为此类one-or- many
属性实现自定义反序列化器。下面我创建了POJO
代表您的JSON
有效负载的简单模型:
class TestResponse {
@SerializedName("test-run")
private TestRun testRun;
// other properties, getters, setters, toString
}
class TestRun {
@SerializedName("test-suite")
private List<TestSuite> testSuite;
// other properties, getters, setters, toString
}
class TestSuite {
private String result;
private double duration;
@SerializedName("test-suite")
private List<TestSuite> testSuites;
@SerializedName("test-case")
private List<TestCase> testCases;
// other properties, getters, setters, toString
}
class TestCase {
private String fullname;
// other properties, getters, setters, toString
}
如您所见test-suite
,它test-case
是List
-es属性。让我们为这些属性实现自定义反序列化器:
class OneOrManyJsonDeserializer<E> implements JsonDeserializer<List<E>> {
private final Class<E> clazz;
public OneOrManyJsonDeserializer(Class<E> clazz) {
this.clazz = clazz;
}
@Override
public List<E> deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
if (json instanceof JsonArray) {
final JsonArray array = (JsonArray) json;
final int size = array.size();
if (size == 0) {
return Collections.emptyList();
}
final List<E> suites = new ArrayList<>(size);
for (int i = 0; i < size; i++) {
suites.add(context.deserialize(array.get(i), clazz));
}
return suites;
}
E suite = context.deserialize(json, clazz);
return Collections.singletonList(suite);
}
}
Class<E>
在运行时需要正确地反序列化JSON object
。之后,让我们创建和自定义Gson
实例:
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.JsonArray;
import com.google.gson.JsonDeserializationContext;
import com.google.gson.JsonDeserializer;
import com.google.gson.JsonElement;
import com.google.gson.JsonParseException;
import com.google.gson.annotations.SerializedName;
import com.google.gson.reflect.TypeToken;
import java.io.File;
import java.io.FileReader;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class GsonApp {
public static void main(String[] args) throws Exception {
File jsonFile = new File("./resource/test.json").getAbsoluteFile();
Type testCaseListType = new TypeToken<List<TestCase>>() {}.getType();
Type testSuiteListType = new TypeToken<List<TestSuite>>() {}.getType();
Gson gson = new GsonBuilder()
.registerTypeAdapter(testCaseListType, new OneOrManyJsonDeserializer<>(TestCase.class))
.registerTypeAdapter(testSuiteListType, new OneOrManyJsonDeserializer<>(TestSuite.class))
.setPrettyPrinting()
.create();
TestResponse response = gson.fromJson(new FileReader(jsonFile), TestResponse.class);
System.out.println(response);
}
}
如您所见,我们为每种one-to-many
类型注册了两个实例。我们需要使用TypeToken
来正确映射我们的实例。
经过上述解决方案,我想出了以下反序列化器:
class OneOrManyJsonDeserializer implements JsonDeserializer<List<?>> {
@Override
public List<?> deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
final Type elementType = $Gson$Types.getCollectionElementType(typeOfT, List.class);
if (json instanceof JsonArray) {
final JsonArray array = (JsonArray) json;
final int size = array.size();
if (size == 0) {
return Collections.emptyList();
}
final List<?> suites = new ArrayList<>(size);
for (int i = 0; i < size; i++) {
suites.add(context.deserialize(array.get(i), elementType));
}
return suites;
}
Object suite = context.deserialize(json, elementType);
return Collections.singletonList(suite);
}
}
我们不需要对其进行自定义。使用$Gson$Types
类,我们可以获得元素的类型并反序列化内部元素。简单用法:
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.JsonArray;
import com.google.gson.JsonDeserializationContext;
import com.google.gson.JsonDeserializer;
import com.google.gson.JsonElement;
import com.google.gson.JsonParseException;
import com.google.gson.annotations.SerializedName;
import com.google.gson.internal.$Gson$Types;
import java.io.File;
import java.io.FileReader;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class GsonApp {
public static void main(String[] args) throws Exception {
File jsonFile = new File("./resource/test.json").getAbsoluteFile();
Gson gson = new GsonBuilder()
.registerTypeAdapter(List.class, new OneOrManyJsonDeserializer())
.setPrettyPrinting()
.create();
TestResponse response = gson.fromJson(new FileReader(jsonFile), TestResponse.class);
System.out.println(response);
}
}
上面的代码也应该为您工作。
我试图将请求体从邮递员映射到spring boot实体,
问题内容: 我需要将obj 映射到一个类及其中的数组,并且它也应该具有所有子级数据。(也嵌套数组列表),我需要再次将更新的数据列表转换为 我的json字符串是 问题答案: 首先, 您需要创建要在其中映射JSON的类。 幸运的是,有一个网站,可以为你做它在这里 其次,您可以使用Google Gson库进行轻松映射 1.添加 依赖项 。 2.从您的对象到JSON。 3.从JSON到object。 有关
问题内容: 我一直在尝试使用PC上的JSON文件将JSON数据映射到Java对象,但是它总是抛出异常: 我的数据类: 我的映射器类: json文件包含以下数据: 我究竟做错了什么?我正在使用Jackson图书馆。 问题答案: 这是我在您的代码中看到的问题列表: 该属性应放在类之上,而不是类之上。查阅文档,最值得注意的是有关“ ignoreUnknown”属性的说法,默认为false: 公共抽象布尔
JSONMappingException:无法反序列化com.demo.json.model.abc实例 编辑:我的POJO如下所示: 有人能提出解决办法吗? 有人能帮我做这个吗?
我使用JAVA jackson将JSON映射到JAVA pojo对象,我的JSON文件是: 在之后,我收到了以下错误消息: 不能反序列化出START_ARRAY令牌 我的POJO课程: 请问,这种JSON格式的正确java POJO是什么?谢谢
我正试图利用谷歌电子表格(谷歌脚本)中的地图功能,使用API从Bittrex获取我的帐户硬币余额。这是我的JSON对象: 理想情况下,我希望根据结果中的键和使用每个对象数据的基础行自动填充标题行。我看到了spme解决方案如何为每种或更复杂的方式使用。但我想这可以通过映射来实现。下面是我如何映射顶行,但不知道如何映射值: 谷歌电子表格中的预期输出为