使用jackson對Java對象與JSON字符串相互轉換的一些總結


本文為菠蘿大象原創,如要轉載請注明出處。http://www.blogjava.net/bolo

 

代碼無真相,為了最簡單的說明,我直接上代碼。

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 去處理,對此還有疑惑的話,可以去看看這兩個方法的
的處理序列化與反序列源碼。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM