總結一下自己使用jackson處理對象與JSON之間相互轉換的心得。 jackson是一個用Java編寫的,用來處理JSON格式數據的類庫,它速度非常快,目前來看使用很廣泛,逐漸替代了Gson和json-lib。
如果直接引入jar包,可以訪問這個地址下載http://jackson.codehaus.org/1.9.11/jackson-all-1.9.11.jar 如果使用maven構建項目,加入下面的依賴<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.11</version>
</dependency> 無代碼無真相,為了最簡單的說明,我直接上代碼。
public class User {
private String name;
private Gender gender;
private List<Account> accounts;
省略get和set方法
...
}
public enum Gender {
MALE,
FEMALE
}public class Account {
private Integer id;
private String cardId;
private BigDecimal balance;
private Date date;
省略get和set方法
...
}public static void main(String[] args) throws Exception {
User user = new User();
user.setName("菠蘿大象");
user.setGender(Gender.MALE);
List<Account> accounts = new ArrayList<Account>();
Account account = new Account();
account.setId(1);
account.setBalance(BigDecimal.valueOf(1900.2));
account.setCardId("423335533434");
account.setDate(new Date());
accounts.add(account);
account = new Account();
account.setId(2);
account.setBalance(BigDecimal.valueOf(5000));
account.setCardId("625444548433");
account.setDate(new Date());
accounts.add(account);
user.setAccounts(accounts);
ObjectMapper mapper = new ObjectMapper();
mapper.configure(SerializationConfig.Feature.INDENT_OUTPUT, Boolean.TRUE);
String json = mapper.writeValueAsString(user);
System.out.println("Java2Json: "+json);
user = mapper.readValue(json, User.class);
System.out.println("Json2Java: "+mapper.writeValueAsString(user));
} mapper.configure(SerializationConfig.Feature.INDENT_OUTPUT, Boolean.TRUE);這是輔助設置,控制格式化輸出。 之前使用的mapper.getSerializationConfig().setXxx方法現在很多都已經被標注為@Deprecated了,因此請大家使用上面的方式處理。 SerializationConfig.Feature枚舉里面還有很多其它的設置項,比如日期,比如要不要輸出null值等等。其它的還有: org.codehaus.jackson.JsonGenerator.Feature.* org.codehaus.jackson.JsonParser.Feature.* 讓我們來看看輸出結果,兩次轉換之后,打印出來的字符串應該是一樣的:
OK,果然結果是一致的,大家現在應該會使用jackson進行Java與Json的互相轉換了吧?恩,現在再考慮一種情況,如果想將List<User>的JSON字符串反轉為泛型,應該怎么做呢? 想這樣:mapper.readValue(json, List<User>.class)?這可是錯誤的,這里的參數是Class<T> valueType,valueType是Class<T>類的對象。如上面所示User.class 就是Class<User>類的對象。因此要想獲得泛型的集合類型需要通過其它辦法:/**
* 獲取泛型的Collection Type
* @param jsonStr json字符串
* @param collectionClass 泛型的Collection
* @param elementClasses 元素類型
*/
public static <T> T readJson(String jsonStr, Class<?> collectionClass, Class<?>... elementClasses) throws Exception { ObjectMapper mapper = new ObjectMapper();
JavaType javaType = mapper.getTypeFactory().constructParametricType(collectionClass, elementClasses);
return mapper.readValue(jsonStr, javaType);
} 定義一個List<User>,向里面添加兩次user,先調用writeValueAsString方法打印出json,再調用readJson方法,這不僅可以轉換泛型List<T>,還可以用于其它集合,比如Map<K,V>等等。
List<User> list = readJson(json,
List.class, User.class); ObjectMapper可以讓對象與JSON之間相互轉換,除此之外Jackson還提供了JsonGenerator 和JsonParser 這兩個類,它們可以更細粒度的處理序列化與反序列化。調用ObjectMapper的writeValueAsString和readValue方法,最終還是會交給JsonGenerator 和JsonParser 去處理,對此還有疑惑的話,可以去看看這兩個方法的源碼。 本文為菠蘿大象原創,如要轉載請注明出處。http://www.tkk7.com/bolo
posted on 2014-04-16 15:48
菠蘿大象 閱讀(59334)
評論(1) 編輯 收藏 所屬分類:
Java