简体   繁体   English

将嵌套的JSON密钥转换为大写

[英]Convert nested JSON Keys to UPPERCASE

I want to convert all keys of JSON string/object to UPPERCASE in Java. 我想将JSON字符串/对象的所有键转换为Java中的大写。 The JSON can be nested. JSON可以嵌套。

I tried setting FieldNamingPolicy.UPPER_CAMEL_CASE in GsonBuilder but I guess that just works for String to JAVA Object and not for String to String. 我尝试在GsonBuilder中设置FieldNamingPolicy.UPPER_CAMEL_CASE,但是我想这仅适用于String到JAVA Object,而不适用于String to String。

 String payload = "{\"key\" : {\"key1\" : \"value1\",\"key2\" : \"value2\"}}";
 GsonBuilder gsonBuilder = new GsonBuilder();
 gsonBuilder.registerTypeAdapterFactory(myCustomTypeAdapterFactory);
 gsonBuilder.setFieldNamingPolicy(FieldNamingPolicy.UPPER_CAMEL_CASE);
 Gson gson = gsonBuilder.create();
 Map mapDeserialized = gson.fromJson(payload, Map.class);

 System.out.println("Map " + mapDeserialized);

There are other solutions through JACKSON with custom TypeAdapterFactory but those only work for one level and not for nested. 通过JACKSON,还有其他带有自定义TypeAdapterFactory的解决方案,但这些解决方案仅适用于一个级别,不适用于嵌套。

{"key" : { "key1" : "value1", "key2" : "value2" }}

to

{"KEY" : { "KEY1" : "value1", "KEY2" : "value2" }}

As you said FieldNamingPolicy is applied only for bean fields not for map keys. 如您所说,FieldNamingPolicy仅适用于bean字段,不适用于地图键。 However UPPER_CAMEL_CASE is not what you want, it is camel case with first letter capitalized (SometingLikeThis). 但是UPPER_CAMEL_CASE不是您想要的,它是驼峰式的,首字母大写(SometingLikeThis)。 You have to implement your own deserializer that would do that for your: 您必须实现自己的解串器,才能为您做到:

import com.google.gson.*;
import com.google.gson.reflect.TypeToken;

import java.lang.reflect.Type;
import java.util.HashMap;
import java.util.Map;

public class UpperCaseAdapter implements JsonSerializer<Map<String, Object>>, JsonDeserializer<Map<String, Object>> {
    public static final Type TYPE = new TypeToken<Map<String, Object>>() {}.getType();

    @Override
    public JsonElement serialize(Map<String, Object> src, Type typeOfSrc, JsonSerializationContext context) {
        // TODO implement serialization if needed
        return null;
    }

    @Override
    public Map<String, Object> deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
        Map<String, Object> map = new HashMap<>();
        for (Map.Entry<String, JsonElement> entry : json.getAsJsonObject().entrySet()) {
            Object value = null;
            if (entry.getValue().isJsonPrimitive()) {
                value = entry.getValue().getAsString();
            } else if (entry.getValue().isJsonObject()) {
                value = context.deserialize(entry.getValue(), TYPE); // deserialize the object using the same type
            } else if (entry.getValue().isJsonArray()) {
                // TODO implement deserailization of array
            } else if (entry.getValue().isJsonNull()) {
                // skip nulls
                continue;
            }
            map.put(entry.getKey().toUpperCase(), value); //toUpperCase() is what we want
        }
        return map;
    }
}

you can use the adapter then: 您可以使用适配器,然后:

        String payload = "{\"key\" : {\"key1\" : \"value1\",\"key2\" : \"value2\"}, \"key3\": \"value\"}";
        Gson gson = new GsonBuilder()
                .registerTypeAdapter(UpperCaseAdapter.TYPE, new UpperCaseAdapter())
                .create();
        Map<String, Object> mapDeserialized = gson.fromJson(payload, UpperCaseAdapter.TYPE);

        System.out.println("Map " + mapDeserialized);

and the output is: Map {KEY3=value, KEY={KEY2=value2, KEY1=value1}} 输出为: Map {KEY3=value, KEY={KEY2=value2, KEY1=value1}}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM