com.jn.easyjson.core.JSON Maven / Gradle / Ivy
/*
* Copyright 2019 the original author or authors.
*
* Licensed under the Apache, 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.gnu.org/licenses/lgpl-3.0.html
*
* 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.
*/
package com.jn.easyjson.core;
import com.jn.easyjson.core.node.JsonNullNode;
import com.jn.langx.util.reflect.type.Primitives;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.Reader;
import java.lang.reflect.Type;
public class JSON {
private static final Logger logger = LoggerFactory.getLogger(JSON.class);
private JsonHandler jsonHandler;
/**
* This method serialize the specified object into its equivalent Json representation.
* This method should be used when the specified object is not a generic type. This method uses
* {@link Class#getClass()} to get the type for the specified object, but the
* {@code getClass()} loses the generic type information because of the Type Erasure feature
* of Java. Note that this method works fine if the any of the object fields are of generic type,
* just the object itself should not be of a generic type. If the object is of generic type, use
* {@link #toJson(Object, Type)} instead.
*/
public String toJson(Object src) {
if (src == null) {
return "";
}
return toJson(src, src.getClass());
}
/**
* This method serialize the specified object, including those of generic types, into its
* equivalent Json representation. This method must be used if the specified object is a generic
* type. For non-generic objects, use {@link #toJson(Object)} instead.
**/
public String toJson(Object src, Type typeOfSrc) {
if (src == null) {
return "";
}
return jsonHandler.serialize(src, typeOfSrc);
}
/**
* 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. For the cases when the object is of generic type, invoke
* {@link #fromJson(String, Type)}.
*
* @param the type of the desired object
* @param json the string from which the object is to be deserialized
* @param classOfT the class of T
* @return an object of type T from the string. Returns {@code null} if {@code json} is {@code null}
* or if {@code json} is empty.
* classOfT d4
*/
public T fromJson(String json, Class classOfT) throws JsonException {
Object object = fromJson(json, (Type) classOfT);
return Primitives.wrap(classOfT).cast(object);
}
/**
* This method deserializes the specified Json into an object of the specified type. This method
* is useful if the specified object is a generic type. For non-generic objects, use
* {@link #fromJson(String, Class)} instead.
*
* @param the type of the desired object
* @param json the string from which the object is to be deserialized
* @param typeOfT The specific genericized type of src. You can obtain this type by using the
* {com.google.gson.reflect.TypeToken} class. For example, to get the type for
* {@code Collection}, you should use:
*
* Type typeOfT = new TypeToken<Collection<Foo>>(){}.getType();
*
* @return an object of type T from the string. Returns {@code null} if {@code json} is {@code null}.
* @throws JsonException if json is not a valid representation for an object of type
*/
@SuppressWarnings("unchecked")
public T fromJson(String json, Type typeOfT) throws JsonException {
if (json == null) {
return null;
}
try {
return jsonHandler.deserialize(json, typeOfT);
} catch (Throwable ex) {
if(logger.isErrorEnabled()) {
logger.error("Error occur when parse json string , error message: {}, json string: {}", ex.getMessage(), json, ex);
}
throw JsonException.wrapAsJsonException(ex);
}
}
public T fromJson(Reader reader, Type typeOfT) throws JsonException {
if (reader == null) {
return null;
}
return jsonHandler.deserialize(reader, typeOfT);
}
public JsonTreeNode fromJson(String json) throws JsonException {
if (json == null) {
return JsonNullNode.INSTANCE;
}
try {
return jsonHandler.deserialize(json);
} catch (Throwable ex) {
if(logger.isErrorEnabled()) {
logger.error("Error occur when parse json string , error message: {}, json string: {}", ex.getMessage(), json, ex);
}
throw JsonException.wrapAsJsonException(ex);
}
}
public T fromJsonTreeNode(JsonTreeNode treeNode, Type typeOfT) {
if (treeNode == null) {
return null;
}
return fromJson(toJson(treeNode), typeOfT);
}
public JSON setJsonHandler(JsonHandler jsonHandler) {
this.jsonHandler = jsonHandler;
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy