[英]Serializing nested org.json.JSONObject using gson.toJson adding into “map” key
在我的代碼中,我需要將一個org.json.JSONObject
添加到另一個使用gson.toJson
序列化的對象。 然而,當這個對象被序列化時, JSONObject
中的值被 gson 本身嵌套到一個映射鍵中。 例如,
public class New {
private static final Gson gson = new GsonBuilder().disableHtmlEscaping().create();
public static void something(User user) throws Exception {
try {
ObjectWriter ow = new ObjectMapper().writer();
String json = ow.writeValueAsString(user);
JSONObject maskedUser = new JSONObject(json);
Nesting testing = new Nesting(maskedUser, "someting");
String something = gson.toJson(testing);
System.out.println(something);
} catch (Exception e) {
throw e;
}
}
public static void main(String[] args) throws Exception {
User user = new User("a", "b", "c");
something(user);
}
}
我收到這樣的輸出 JSON
{"details":{"map":{"lastname":"b","firstname":"a","password":"c"}},"sometim":"someting"}
我需要知道如何避免 gson 解析器自動添加的map
鍵。
編輯:我剛剛發現 gson 在序列化對象內的數組時還會添加一個"myArrayList"
。 這非常令人沮喪,並使解析 JSON 變得困難和煩人。
"map":{"fruits":{"myArrayList":["Apples"]}
用戶 GsonBuilder 創建 Gson。 注冊自定義 TypeAdapter
new GsonBuilder()
.registerTypeAdapter(JSONObject.class, JSONObjectAdapter.sInstance)
.registerTypeAdapter(JSONArray.class, JSONArrayAdapter.sInstance)
JSONObjectAdapter.jva
static class JSONObjectAdapter implements JsonSerializer<JSONObject>, JsonDeserializer<JSONObject> {
public static JSONObjectAdapter sInstance = new JSONObjectAdapter();
@Override
public JsonElement serialize(JSONObject src, Type typeOfSrc, JsonSerializationContext context) {
if (src == null) {
return null;
}
JsonObject jsonObject = new JsonObject();
Iterator<String> keys = src.keys();
while (keys.hasNext()) {
String key = keys.next();
Object value = src.opt(key);
JsonElement jsonElement = context.serialize(value, value.getClass());
jsonObject.add(key, jsonElement);
}
return jsonObject;
}
@Override
public JSONObject deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
if (json == null) {
return null;
}
try {
return new JSONObject(json.toString());
} catch (JSONException e) {
e.printStackTrace();
throw new JsonParseException(e);
}
}
}
JSONArrayAdapter.java
static class JSONArrayAdapter implements JsonSerializer<JSONArray>, JsonDeserializer<JSONArray> {
public static final JSONArrayAdapter sInstance = new JSONArrayAdapter();
@Override
public JsonElement serialize(JSONArray src, Type typeOfSrc, JsonSerializationContext context) {
if (src == null) {
return null;
}
JsonArray jsonArray = new JsonArray();
for (int i = 0; i < src.length(); i++) {
Object object = src.opt(i);
JsonElement jsonElement = context.serialize(object, object.getClass());
jsonArray.add(jsonElement);
}
return jsonArray;
}
@Override
public JSONArray deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
if (json == null) {
return null;
}
try {
return new JSONArray(json.toString());
} catch (JSONException e) {
e.printStackTrace();
throw new JsonParseException(e);
}
}
}
嘗試使用com.google.gson.JsonObject
而不是JSONObject
。 請看這個。
如果有人想知道如何解決這個問題,我通過執行以下操作找到了解決方案:
public static void something(User user) throws Exception {
try {
ObjectWriter ow = new ObjectMapper().writer();
String json = ow.writeValueAsString(user);
Nesting testing = new Nesting(null, "someting");
Object object = gson.fromJson(json, Object.class);
testing.setDetails(object);
JsonElement something = gson.toJsonTree(testing);
System.out.println(something);
} catch (Exception e) {
throw e;
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.