實用的Json工具類(Gson)

jopen 12年前發布 | 89K 次閱讀 JSON開發包 JSON

涉及到的jar包主要是gson-2.0.jar(必須,google做了封裝所以是gson),log4j.jar(可選)

 

使用范圍:所有對象

 

使用方法:

1,對象轉json

String aStr = JsonUtils.toJson(A, false);

參數1具體對象(A代表任何對象,可以使集合類型也可以是普通類型),

參數2:是否轉換只標注有@Expose的屬性,比如說在A中有下列屬性:

 private String resultCode;
 
@Expose
 private String exception;
 private String startTime;

......get...

......set...

那么在做轉換的時候只有屬性exception才會被轉換,并且不能為null(即使參數2設置為false,為null的屬性也不做轉換)

 

 

2,json轉對象

 A  a = JsonUtils.fromJson(aStr, A.calss);//參數1是通過json轉后的string,參數2:目標對象

 

注意如果是把List轉Json String,在取出的時候不能直接用foreach循環取出

平常我們可能就用如下方式就可以了

for (Person person: personList) {

Student stu =   person.getStudent();
  }

而通過json轉之后這樣就不可以了,會拋出java.util.LinkedHashMap cannot be cast to Person

 

可以采用如下方式

List personList= JsonUtils.fromJson(str,List.class); //str是List轉為的string類型,上面有說怎么轉。

personList:我里面裝的雖然是人,但要采用正確的方式把他們放出來,要不然就不是人了

for (int i = 0; i < personList.size(); i++) {

    ③請先把我轉為String吧,要不然我就回不去了

     String personStr = JsonUtils.toJson(personList.get(i), false);

     哈哈,我可以變成人了

    Person person= JsonUtils.fromJson(personStr ,Person.class);

    ⑤good,還可以取到錢

     Money money = person.getMoney()

    ⑥:你醒醒吧⑤,像我這樣才可以取到錢

    String moneyStr = JsonUtils.toJson(person.getMoney());

    ⑦有錢了\(0^◇^0)/
    Money money = JsonUtils.fromJson(moneyStr , Money.class);

 

 

 

 

 

PS:對象中的int,Integer,Long long..等數字類型屬性,通過json轉回來時會多出 .0

 

 工具類代碼如下:

import java.lang.reflect.Type;
import java.util.Collection;
import java.util.Enumeration;
import java.util.Iterator;

import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory;

import com.google.gson.Gson; import com.google.gson.GsonBuilder; import com.google.gson.reflect.TypeToken;

public class JsonUtils { private static final Log log = LogFactory.getLog(JsonUtils.class); public static final String EMPTY = ""; / 空的 {@code JSON} 數據 - <code>"{}"</code>。 */ public static final String EMPTY_JSON = "{}"; / 空的 {@code JSON} 數組(集合)數據 - {@code "[]"}。 / public static final String EMPTY_JSON_ARRAY = "[]"; /** 默認的 {@code JSON} 日期/時間字段的格式化模式。 / public static final String DEFAULT_DATE_PATTERN = "yyyy-MM-dd HH:mm:ss SSS"; / {@code Google Gson} 的 {@literal @Since} 注解常用的版本號常量 - {@code 1.0}。 */ public static final Double SINCE_VERSION_10 = 1.0d; / {@code Google Gson} 的 {@literal @Since} 注解常用的版本號常量 - {@code 1.1}。 / public static final Double SINCE_VERSION_11 = 1.1d; /** {@code Google Gson} 的 {@literal @Since} 注解常用的版本號常量 - {@code 1.2}。 / public static final Double SINCE_VERSION_12 = 1.2d;

/**
 * 將給定的目標對象根據指定的條件參數轉換成 {@code JSON} 格式的字符串。
 * <p />
 * <strong>該方法轉換發生錯誤時,不會拋出任何異常。若發生錯誤時,曾通對象返回 <code>"{}"</code>; 集合或數組對象返回
 * <code>"[]"</code></strong>
 * 
 * @param target
 *            目標對象。
 * @param targetType
 *            目標對象的類型。
 * @param isSerializeNulls
 *            是否序列化 {@code null} 值字段。
 * @param version
 *            字段的版本號注解。
 * @param datePattern
 *            日期字段的格式化模式。
 * @param excludesFieldsWithoutExpose
 *            是否排除未標注 {@literal @Expose} 注解的字段。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target, Type targetType,
        boolean isSerializeNulls, Double version, String datePattern,
        boolean excludesFieldsWithoutExpose) {
    if (target == null)
        return EMPTY_JSON;
    GsonBuilder builder = new GsonBuilder();
    if (isSerializeNulls)
        builder.serializeNulls();
    if (version != null)
        builder.setVersion(version.doubleValue());
    if (isEmpty(datePattern))
        datePattern = DEFAULT_DATE_PATTERN;
    builder.setDateFormat(datePattern);
    if (excludesFieldsWithoutExpose)
        builder.excludeFieldsWithoutExposeAnnotation();
    String result = EMPTY;
    Gson gson = builder.create();
    try {
        if (targetType != null) {
            result = gson.toJson(target, targetType);
        } else {
            result = gson.toJson(target);
        }
    } catch (Exception ex) {
        log.warn("目標對象 " + target.getClass().getName()
                + " 轉換 JSON 字符串時,發生異常!", ex);
        if (target instanceof Collection || target instanceof Iterator
                || target instanceof Enumeration
                || target.getClass().isArray()) {
            result = EMPTY_JSON_ARRAY;
        } else
            result = EMPTY_JSON;
    }
    return result;
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法只用來轉換普通的 {@code JavaBean}
 * 對象。</strong>
 * <ul>
 * <li>該方法只會轉換標有 {@literal @Expose} 注解的字段;</li>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法會轉換所有未標注或已標注 {@literal @Since} 的字段;</li>
 * <li>該方法轉換時使用默認的 日期/時間 格式化模式 - {@code yyyy-MM-dd HH:mm:ss SSS};</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target) {
    return toJson(target, null, false, null, null, true);
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法只用來轉換普通的 {@code JavaBean}
 * 對象。</strong>
 * <ul>
 * <li>該方法只會轉換標有 {@literal @Expose} 注解的字段;</li>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法會轉換所有未標注或已標注 {@literal @Since} 的字段;</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @param datePattern
 *            日期字段的格式化模式。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target, String datePattern) {
    return toJson(target, null, false, null, datePattern, true);
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法只用來轉換普通的 {@code JavaBean}
 * 對象。</strong>
 * <ul>
 * <li>該方法只會轉換標有 {@literal @Expose} 注解的字段;</li>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法轉換時使用默認的 日期/時間 格式化模式 - {@code yyyy-MM-dd HH:mm:ss SSS};</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @param version
 *            字段的版本號注解({@literal @Since})。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target, Double version) {
    return toJson(target, null, false, version, null, true);
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法只用來轉換普通的 {@code JavaBean}
 * 對象。</strong>
 * <ul>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法會轉換所有未標注或已標注 {@literal @Since} 的字段;</li>
 * <li>該方法轉換時使用默認的 日期/時間 格式化模式 - {@code yyyy-MM-dd HH:mm:ss SSS};</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @param excludesFieldsWithoutExpose
 *            是否排除未標注 {@literal @Expose} 注解的字段。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target,
        boolean excludesFieldsWithoutExpose) {
    return toJson(target, null, false, null, null,
            excludesFieldsWithoutExpose);
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法只用來轉換普通的 {@code JavaBean}
 * 對象。</strong>
 * <ul>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法轉換時使用默認的 日期/時間 格式化模式 - {@code yyyy-MM-dd HH:mm:ss SSS};</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @param version
 *            字段的版本號注解({@literal @Since})。
 * @param excludesFieldsWithoutExpose
 *            是否排除未標注 {@literal @Expose} 注解的字段。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target, Double version,
        boolean excludesFieldsWithoutExpose) {
    return toJson(target, null, false, version, null,
            excludesFieldsWithoutExpose);
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法通常用來轉換使用泛型的對象。</strong>
 * <ul>
 * <li>該方法只會轉換標有 {@literal @Expose} 注解的字段;</li>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法會轉換所有未標注或已標注 {@literal @Since} 的字段;</li>
 * <li>該方法轉換時使用默認的 日期/時間 格式化模式 - {@code yyyy-MM-dd HH:mm:ss SSSS};</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @param targetType
 *            目標對象的類型。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target, Type targetType) {
    return toJson(target, targetType, false, null, null, true);
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法通常用來轉換使用泛型的對象。</strong>
 * <ul>
 * <li>該方法只會轉換標有 {@literal @Expose} 注解的字段;</li>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法轉換時使用默認的 日期/時間 格式化模式 - {@code yyyy-MM-dd HH:mm:ss SSSS};</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @param targetType
 *            目標對象的類型。
 * @param version
 *            字段的版本號注解({@literal @Since})。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target, Type targetType, Double version) {
    return toJson(target, targetType, false, version, null, true);
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法通常用來轉換使用泛型的對象。</strong>
 * <ul>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法會轉換所有未標注或已標注 {@literal @Since} 的字段;</li>
 * <li>該方法轉換時使用默認的 日期/時間 格式化模式 - {@code yyyy-MM-dd HH:mm:ss SSS};</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @param targetType
 *            目標對象的類型。
 * @param excludesFieldsWithoutExpose
 *            是否排除未標注 {@literal @Expose} 注解的字段。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target, Type targetType,
        boolean excludesFieldsWithoutExpose) {
    return toJson(target, targetType, false, null, null,
            excludesFieldsWithoutExpose);
}

/**
 * 將給定的目標對象轉換成 {@code JSON} 格式的字符串。<strong>此方法通常用來轉換使用泛型的對象。</strong>
 * <ul>
 * <li>該方法不會轉換 {@code null} 值字段;</li>
 * <li>該方法轉換時使用默認的 日期/時間 格式化模式 - {@code yyyy-MM-dd HH:mm:ss SSS};</li>
 * </ul>
 * 
 * @param target
 *            要轉換成 {@code JSON} 的目標對象。
 * @param targetType
 *            目標對象的類型。
 * @param version
 *            字段的版本號注解({@literal @Since})。
 * @param excludesFieldsWithoutExpose
 *            是否排除未標注 {@literal @Expose} 注解的字段。
 * @return 目標對象的 {@code JSON} 格式的字符串。
 */
public static String toJson(Object target, Type targetType, Double version,
        boolean excludesFieldsWithoutExpose) {
    return toJson(target, targetType, false, version, null,
            excludesFieldsWithoutExpose);
}

/**
 * 將給定的 {@code JSON} 字符串轉換成指定的類型對象。
 * 
 * @param <T>
 *            要轉換的目標類型。
 * @param json
 *            給定的 {@code JSON} 字符串。
 * @param token
 *            {@code com.google.gson.reflect.TypeToken} 的類型指示類對象。
 * @param datePattern
 *            日期格式模式。
 * @return 給定的 {@code JSON} 字符串表示的指定的類型對象。
 */
public static <T> T fromJson(String json, TypeToken<T> token,
        String datePattern) {
    if (isEmpty(json)) {
        return null;
    }
    GsonBuilder builder = new GsonBuilder();
    if (isEmpty(datePattern)) {
        datePattern = DEFAULT_DATE_PATTERN;
    }
    Gson gson = builder.create();
    try {
        return gson.fromJson(json, token.getType());
    } catch (Exception ex) {
        log.error(json + " 無法轉換為 " + token.getRawType().getName() + " 對象!",
                ex);
        return null;
    }
}

/**
 * 將給定的 {@code JSON} 字符串轉換成指定的類型對象。
 * 
 * @param <T>
 *            要轉換的目標類型。
 * @param json
 *            給定的 {@code JSON} 字符串。
 * @param token
 *            {@code com.google.gson.reflect.TypeToken} 的類型指示類對象。
 * @return 給定的 {@code JSON} 字符串表示的指定的類型對象。
 */
public static <T> T fromJson(String json, TypeToken<T> token) {
    return fromJson(json, token, null);
}

/**
 * 將給定的 {@code JSON} 字符串轉換成指定的類型對象。<strong>此方法通常用來轉換普通的 {@code JavaBean}
 * 對象。</strong>
 * 
 * @param <T>
 *            要轉換的目標類型。
 * @param json
 *            給定的 {@code JSON} 字符串。
 * @param clazz
 *            要轉換的目標類。
 * @param datePattern
 *            日期格式模式。
 * @return 給定的 {@code JSON} 字符串表示的指定的類型對象。
 */
public static <T> T fromJson(String json, Class<T> clazz, String datePattern) {
    if (isEmpty(json)) {
        return null;
    }
    GsonBuilder builder = new GsonBuilder();
    if (isEmpty(datePattern)) {
        datePattern = DEFAULT_DATE_PATTERN;
    }
    Gson gson = builder.create();
    try {
        return gson.fromJson(json, clazz);
    } catch (Exception ex) {
        log.error(json + " 無法轉換為 " + clazz.getName() + " 對象!", ex);
        return null;
    }
}

/**
 * 將給定的 {@code JSON} 字符串轉換成指定的類型對象。<strong>此方法通常用來轉換普通的 {@code JavaBean}
 * 對象。</strong>
 * 
 * @param <T>
 *            要轉換的目標類型。
 * @param json
 *            給定的 {@code JSON} 字符串。
 * @param clazz
 *            要轉換的目標類。
 * @return 給定的 {@code JSON} 字符串表示的指定的類型對象。
 */
public static <T> T fromJson(String json, Class<T> clazz) {
    return fromJson(json, clazz, null);
}

public static boolean isEmpty(String inStr) {
    boolean reTag = false;
    if (inStr == null || "".equals(inStr)) {
        reTag = true;
    }
    return reTag;
}

}</pre>轉自: http://learning.iteye.com/blog/1322972

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!