亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

GSON 為特定字段動態地將整數值轉換為布爾值

GSON 為特定字段動態地將整數值轉換為布爾值

偶然的你 2022-07-27 21:40:08
如何處理獲得相同名稱但不同類型的字段?在同一個請求中,我有時會從 API 獲取整數值,有時會獲取布爾值。我想知道當我得到這樣的 Json 時如何處理。我創建了類型適配器,但它不起作用我考慮過創建不同的 POJO 類。但是這個問題不僅僅針對一個請求。由于這個原因,我不喜歡創建 POJO。順便說一句,我看到了類似的問題,但它并沒有解決我的問題。{  "name" : "john doe",  "isValid" : true }有時我會明白{  "name" : "john doe",  "isValid" : 1 }獲取整數時出現意外的 json 異常class XModel{    private boolean isValid;    ...    ...}我想為每個請求返回一個布爾值。有誰知道如何解決這個問題?編輯:我想通過類型適配器防止 instanceOf 關鍵字解決方案:@Micha? Ziober 的回應對我有用。class BooleanJsonDeserializer implements JsonDeserializer<Boolean> {    private final Set<String> TRUE_STRINGS = new HashSet<>(Arrays.asList("true", "1", "yes"));    @Override    public Boolean deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {        System.out.println(json);        JsonPrimitive jsonPrimitive = json.getAsJsonPrimitive();        if (jsonPrimitive.isBoolean()) {            return jsonPrimitive.getAsBoolean();        } else if (jsonPrimitive.isNumber()) {            return jsonPrimitive.getAsNumber().intValue() == 1;        } else if (jsonPrimitive.isString()) {            return TRUE_STRINGS.contains(jsonPrimitive.getAsString().toLowerCase());        }        return false;    }}
查看完整描述

3 回答

?
胡子哥哥

TA貢獻1825條經驗 獲得超6個贊

如果XModel類不大,您可以編寫自定義反序列化器,如下所示,您可以控制傳入元素:


import com.google.gson.Gson;

import com.google.gson.GsonBuilder;

import com.google.gson.JsonDeserializationContext;

import com.google.gson.JsonDeserializer;

import com.google.gson.JsonElement;

import com.google.gson.JsonObject;

import com.google.gson.JsonParseException;

import com.google.gson.JsonPrimitive;


import java.io.File;

import java.io.FileReader;

import java.lang.reflect.Type;

import java.util.Arrays;

import java.util.HashSet;

import java.util.Set;


public class GsonApp {


    public static void main(String[] args) throws Exception {

        File jsonFile = new File("./resource/test.json").getAbsoluteFile();


        Gson gson = new GsonBuilder()

                .registerTypeAdapter(XModel.class, new XModelJsonDeserializer())

                .create();


        System.out.println(gson.fromJson(new FileReader(jsonFile), XModel.class));

    }

}


class XModelJsonDeserializer implements JsonDeserializer<XModel> {


    private final Set<String> TRUE_STRINGS = new HashSet<>(Arrays.asList("true", "1", "yes"));


    @Override

    public XModel deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {

        XModel response = new XModel();

        JsonObject jsonResponse = (JsonObject) json;

        response.setName(jsonResponse.get("name").getAsString());

        // other fields


        JsonElement dataElement = jsonResponse.get("isValid");

        if (dataElement.isJsonNull()) {

            response.setValid(false);

        } else if (dataElement.isJsonPrimitive()) {

            JsonPrimitive jsonPrimitive = dataElement.getAsJsonPrimitive();

            if (jsonPrimitive.isBoolean()) {

                response.setValid(jsonPrimitive.getAsBoolean());

            } else if (jsonPrimitive.isNumber()) {

                response.setValid(jsonPrimitive.getAsNumber().intValue() == 1);

            } else if (jsonPrimitive.isString()) {

                response.setValid(TRUE_STRINGS.contains(jsonPrimitive.getAsString()));

            }

            System.out.println("Json data is primitive: " + dataElement.getAsString());

        } else if (dataElement.isJsonObject() || dataElement.isJsonArray()) {

            response.setValid(true); //?!?!

        }


        return response;

    }

}

對于以下JSON有效載荷:


{

  "name" : "john doe",

  "isValid" : true

}

上面的程序打?。?/p>


Json data is primitive: true

XModel{name='john doe', isValid=true}

對于JSON有效載荷:


{

  "name" : "john doe",

  "isValid" : 1

}

印刷:


Json data is primitive: 1

XModel{name='john doe', isValid=true}

您的模型很清楚,因為所有工作都是在反序列化器級別完成的。


更精確的解決方案是primitive僅序列化。假設模型如下所示:


class XModel {


    private String name;


    @JsonAdapter(value = BooleanJsonDeserializer.class)

    private boolean isValid;


    // getters, setters

}

我們的BooleanJsonDeserializer反序列化器如下所示:


class BooleanJsonDeserializer implements JsonDeserializer<Boolean> {


    private final Set<String> TRUE_STRINGS = new HashSet<>(Arrays.asList("true", "1", "yes"));


    @Override

    public Boolean deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {

        System.out.println(json);

        JsonPrimitive jsonPrimitive = json.getAsJsonPrimitive();

        if (jsonPrimitive.isBoolean()) {

            return jsonPrimitive.getAsBoolean();

        } else if (jsonPrimitive.isNumber()) {

            return jsonPrimitive.getAsNumber().intValue() == 1;

        } else if (jsonPrimitive.isString()) {

            return TRUE_STRINGS.contains(jsonPrimitive.getAsString().toLowerCase());

        }


        return false;

    }

}

您只需要boolean在模型中使用此適配器注釋每個屬性,它就可以處理:1、、True等。


查看完整回答
反對 回復 2022-07-27
?
慕虎7371278

TA貢獻1802條經驗 獲得超4個贊

我不相信執行此映射很容易,但以下內容可能會有所幫助。


public void setIsValid(Object isValid) {

    String isValidString = String.valueOf(isValid).replace("0", "false").replace("1", "true");

    return Boolean.valueOf(isValidString);

}


查看完整回答
反對 回復 2022-07-27
?
隔江千里

TA貢獻1906條經驗 獲得超10個贊

你可以看看Apache Commons Lang BooleanUtilities。有一種方法可以將不同類型的字符串(和其他對象)解析為布爾值。


System.out.println(BooleanUtils.toBoolean(1));

System.out.println(BooleanUtils.toBoolean(true));

System.out.println(BooleanUtils.toBoolean("TrUe"));

System.out.println(BooleanUtils.toBoolean("true"));

輸出


true

true

true

true

但是 BooleanUtils.toBoolean("1");,false您可以像這樣組合它:


String isValid = jsonPrimitive.get("isValid").getAsString();

System.out.println(BooleanUtils.toBoolean(isValid) || isValid.equals("1"));


查看完整回答
反對 回復 2022-07-27
  • 3 回答
  • 0 關注
  • 143 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號