jackson 进行json与java对象转换 之一

 

代码无真相,为了最简单的说明,我直接上代码。

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.*     让我们来看看输出

复制代码
Java2Json:{
  "name" : "菠萝大象",
  "gender" : "MALE",
  "accounts" : [ { 
     "id" : 1,
     "cardId" : "423335533434",
     "balance" : 1900.2,
     "date" : 1397542291453
   }, {
      "id" : 1,
     "cardId" : "625444548433",
     "balance" : 5000,
     "date" : 1397542291453
    } ]    
}

Json2Java:{
  "name" : "菠萝大象",
  "gender" : "MALE",
  "accounts" : [ { 
     "id" : 1,
     "cardId" : "423335533434",
     "balance" : 1900.2,
     "date" : 1397542291453
   }, {
      "id" : 1,
     "cardId" : "625444548433",
     "balance" : 5000,
     "date" : 1397542291453
    } ]    
}
复制代码

 

结果,两次转换之后,打印出来的字符串应该是一样的:          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 去处理,对此还有疑惑的话,可以去看看这两个方法的的处理序列化与反序列源码。

 
posted @   迷走神经  阅读(208)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
点击右上角即可分享
微信分享提示