JSONUtils.java 8.9 KB
Newer Older
L
ligang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
Q
qiaozhanwei 已提交
17
package org.apache.dolphinscheduler.common.utils;
L
ligang 已提交
18

19 20 21 22 23 24 25 26 27 28 29
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.TimeZone;

import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

L
ligang 已提交
30 31
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.core.JsonParser;
32
import com.fasterxml.jackson.core.type.TypeReference;
33 34 35 36 37 38 39 40 41
import com.fasterxml.jackson.databind.DeserializationContext;
import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.JsonDeserializer;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.JsonSerializer;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.databind.SerializerProvider;
42 43
import com.fasterxml.jackson.databind.node.ArrayNode;
import com.fasterxml.jackson.databind.node.ObjectNode;
44
import com.fasterxml.jackson.databind.node.TextNode;
S
simon824 已提交
45
import com.fasterxml.jackson.databind.type.CollectionType;
L
ligang 已提交
46 47 48 49 50 51 52


/**
 * json utils
 */
public class JSONUtils {

53 54 55 56 57 58 59 60
    private static final Logger logger = LoggerFactory.getLogger(JSONUtils.class);

    /**
     * can use static singleton, inject: just make sure to reuse!
     */
    private static final ObjectMapper objectMapper = new ObjectMapper();

    private JSONUtils() {
L
ligang 已提交
61 62
    }

63 64 65 66
    static {
        //Feature that determines whether encountering of unknown properties, false means not analyzer unknown properties
        objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false).setTimeZone(TimeZone.getDefault());
        objectMapper.configure(DeserializationFeature.ACCEPT_EMPTY_ARRAY_AS_NULL_OBJECT, true).setTimeZone(TimeZone.getDefault());
L
ligang 已提交
67 68
    }

S
simon824 已提交
69

张世鸣 已提交
70 71 72 73 74 75 76 77 78 79 80 81
    public static ArrayNode createArrayNode() {
        return objectMapper.createArrayNode();
    }

    public static ObjectNode createObjectNode() {
        return objectMapper.createObjectNode();
    }

    public static JsonNode toJsonNode(Object obj) {
        return objectMapper.valueToTree(obj);
    }

82 83 84 85
    /**
     * json representation of object
     *
     * @param object object
张世鸣 已提交
86
     * @param feature feature
87 88
     * @return object to json string
     */
张世鸣 已提交
89
    public static String toJsonString(Object object, SerializationFeature feature) {
90
        try {
张世鸣 已提交
91 92
            ObjectWriter writer = objectMapper.writer(feature);
            return writer.writeValueAsString(object);
93 94 95 96 97
        } catch (Exception e) {
            logger.error("object to json exception!", e);
        }

        return null;
L
ligang 已提交
98
    }
99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124

    /**
     * This method deserializes the specified Json into an object of the specified class. It is not
     * suitable to use if the specified class is a generic type since it will not have the generic
     * type information because of the Type Erasure feature of Java. Therefore, this method should not
     * be used if the desired type is a generic type. Note that this method works fine if the any of
     * the fields of the specified object are generics, just the object itself should not be a
     * generic type.
     *
     * @param json  the string from which the object is to be deserialized
     * @param clazz the class of T
     * @param <T>   T
     * @return an object of type T from the string
     * classOfT
     */
    public static <T> T parseObject(String json, Class<T> clazz) {
        if (StringUtils.isEmpty(json)) {
            return null;
        }

        try {
            return objectMapper.readValue(json, clazz);
        } catch (Exception e) {
            logger.error("parse object exception!", e);
        }
        return null;
L
ligang 已提交
125
    }
126 127 128 129 130 131 132 133 134 135 136

    /**
     * json to list
     *
     * @param json  json string
     * @param clazz class
     * @param <T>   T
     * @return list
     */
    public static <T> List<T> toList(String json, Class<T> clazz) {
        if (StringUtils.isEmpty(json)) {
137
            return Collections.emptyList();
138
        }
S
simon824 已提交
139

140
        try {
S
simon824 已提交
141 142 143

            CollectionType listType = objectMapper.getTypeFactory().constructCollectionType(ArrayList.class, clazz);
            return objectMapper.readValue(json, listType);
144
        } catch (Exception e) {
S
simon824 已提交
145
            logger.error("parse list exception!", e);
146 147
        }

148
        return Collections.emptyList();
L
ligang 已提交
149 150 151
    }


152 153 154 155 156 157 158
    /**
     * check json object valid
     *
     * @param json json
     * @return true if valid
     */
    public static boolean checkJsonValid(String json) {
L
ligang 已提交
159

160 161 162
        if (StringUtils.isEmpty(json)) {
            return false;
        }
L
ligang 已提交
163

164 165 166 167 168 169
        try {
            objectMapper.readTree(json);
            return true;
        } catch (IOException e) {
            logger.error("check json object valid exception!", e);
        }
L
ligang 已提交
170

171
        return false;
L
ligang 已提交
172 173 174
    }


175 176 177 178 179 180 181 182 183 184 185
    /**
     * Method for finding a JSON Object field with specified name in this
     * node or its child nodes, and returning value it has.
     * If no matching field is found in this node or its descendants, returns null.
     *
     * @param jsonNode  json node
     * @param fieldName Name of field to look for
     * @return Value of first matching node found, if any; null if none
     */
    public static String findValue(JsonNode jsonNode, String fieldName) {
        JsonNode node = jsonNode.findValue(fieldName);
L
ligang 已提交
186

187 188 189
        if (node == null) {
            return null;
        }
L
ligang 已提交
190

191
        return node.toString();
L
ligang 已提交
192 193
    }

194 195 196 197 198 199 200 201 202 203 204

    /**
     * json to map
     * <p>
     * {@link #toMap(String, Class, Class)}
     *
     * @param json json
     * @return json to map
     */
    public static Map<String, String> toMap(String json) {
        if (StringUtils.isEmpty(json)) {
S
simon824 已提交
205
            return null;
206 207 208 209 210 211 212 213
        }

        try {
            return objectMapper.readValue(json, new TypeReference<Map<String, String>>() {});
        } catch (Exception e) {
            logger.error("json to map exception!", e);
        }

S
simon824 已提交
214
        return null;
L
ligang 已提交
215 216
    }

217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239
    /**
     * json to map
     *
     * @param json   json
     * @param classK classK
     * @param classV classV
     * @param <K>    K
     * @param <V>    V
     * @return to map
     */
    public static <K, V> Map<K, V> toMap(String json, Class<K> classK, Class<V> classV) {
        if (StringUtils.isEmpty(json)) {
            return null;
        }

        try {
            return objectMapper.readValue(json, new TypeReference<Map<K, V>>() {
            });
        } catch (Exception e) {
            logger.error("json to map exception!", e);
        }

        return null;
L
ligang 已提交
240 241
    }

242 243 244 245 246 247 248 249 250 251 252 253
    /**
     * object to json string
     *
     * @param object object
     * @return json string
     */
    public static String toJsonString(Object object) {
        try {
            return objectMapper.writeValueAsString(object);
        } catch (Exception e) {
            throw new RuntimeException("Object json deserialization exception.", e);
        }
L
ligang 已提交
254 255
    }

256 257 258 259 260 261
    public static ObjectNode parseObject(String text) {
        try {
            return (ObjectNode) objectMapper.readTree(text);
        } catch (Exception e) {
            throw new RuntimeException("String json deserialization exception.", e);
        }
262 263
    }

264 265 266 267 268 269
    public static ArrayNode parseArray(String text) {
        try {
            return (ArrayNode) objectMapper.readTree(text);
        } catch (Exception e) {
            throw new RuntimeException("Json deserialization exception.", e);
        }
270 271
    }

L
ligang 已提交
272

273 274 275 276
    /**
     * json serializer
     */
    public static class JsonDataSerializer extends JsonSerializer<String> {
L
ligang 已提交
277

278 279 280 281
        @Override
        public void serialize(String value, JsonGenerator gen, SerializerProvider provider) throws IOException {
            gen.writeRawValue(value);
        }
L
ligang 已提交
282 283 284

    }

285 286 287 288
    /**
     * json data deserializer
     */
    public static class JsonDataDeserializer extends JsonDeserializer<String> {
L
ligang 已提交
289

290 291 292
        @Override
        public String deserialize(JsonParser p, DeserializationContext ctxt) throws IOException {
            JsonNode node = p.getCodec().readTree(p);
293 294 295 296 297
            if (node instanceof TextNode) {
                return node.asText();
            } else {
                return node.toString();
            }
298
        }
L
ligang 已提交
299 300 301

    }
}