實用的Json工具類(Gson)
涉及到的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