• json序列化(javaBean转Json细节处理)


    前言


     

    Java对象在转json的时候,如果对象里面有属性值为null的话,那么在json序列化的时候要不要序列出来呢?对比以下json转换方式

    三种常见的json jar序列化


    fastjson

    1.阿里巴巴提供的fastjson,当用json转换实体类时;

      --无get开头的方法,将找不到序列器。

      --如果有get开头的方法,但是无此get方法后面的字段,也找不到序列器[元数据一体化的项目落到此坑]。

      --证明它与get开头的方法有关。

      --fastJson在转换java对象为json的时候,fastjson默认转换是不序列化null值对应的key的。

        //当字段为基本数据类型时,例如当字段类型为int类型时:
        private int start;
        private int limit;
    // 我如果不set值的时候,会序列化为下面这样
    "limit":0,"start":0

      默认为都是0了,而我的目标是如果不设置值的时候,它们不会出现。

      我是简单地通过把他们的类型改为Integer了。应该有其它通过自定义序列化行为的方式来解决,暂不研究。

    但是如果想把null对应的key序列化出来呢?
    那就要仔细看看fastjson转换java对象为json的时候的入参了:也就是这个方法:
    JSONObject.toJSONString(Object object, SerializerFeature... features)
    Fastjson的SerializerFeature序列化属性:
    1、QuoteFieldNames———-输出key时是否使用双引号,默认为true
    2、WriteMapNullValue——–是否输出值为null的字段,默认为false
    3、WriteNullNumberAsZero—-数值字段如果为null,输出为0,而非null
    4、WriteNullListAsEmpty—–List字段如果为null,输出为[],而非null
    5、WriteNullStringAsEmpty—字符类型字段如果为null,输出为”“,而非null
    6、WriteNullBooleanAsFalse–Boolean字段如果为null,输出为false,而非null
    结合上面,SerializerFeature... features是个数组,那么我们可以传入我们想要的参数,比如想序列化null,案例如下:
    public static void main(String[] args) {
    AutoPartsSearchRequest request = new AutoPartsSearchRequest();
    request.setKeywords("123");
    request.setSortingField("234242");
    String str = JSONObject.toJSONString(request, SerializerFeature.WriteMapNullValue);
    System.out.println(str);
    }

    Jackson

    2.java开源的Jackson类,也与get开头的方法有关【同上】。

    jackson默认是序列化null对应的key的,也就是说不管你对象属性有没有值,在转换json的时候都会被序列化出来
    public static void main(String[] args) throws JsonGenerationException, JsonMappingException, IOException {
    AutoPartsSearchRequest request = new AutoPartsSearchRequest();
    request.setKeywords("123");
    request.setSortingField("234242");
    ObjectMapper mapper = new ObjectMapper();
    String str = mapper.writeValueAsString(request);
    System.out.println(str);
    //输出结果(此处就不格式化了):{"sortingField":"234242","partsClassifyId":null,"partsSubClassifyId":null,"sortingDirection":null:......
    }
    同理,想要不序列化null也是可以的,具体如下:
    1.实体上
     
    @JsonInclude(Include.NON_NULL)
     
    //将该标记放在属性上,如果该属性为NULL则不参与序列化
    //如果放在类上边,那对这个类的全部属性起作用
    //Include.Include.ALWAYS 默认
    //Include.NON_DEFAULT 属性为默认值不序列化
    //Include.NON_EMPTY 属性为 空(“”) 或者为 NULL 都不序列化
    //Include.NON_NULL 属性为NULL 不序列化
     
     
    2.代码上
    ObjectMapper mapper = new ObjectMapper();
     
    mapper.setSerializationInclusion(Include.NON_NULL);
     
    //通过该方法对mapper对象进行设置,所有序列化的对象都将按改规则进行系列化
    //Include.Include.ALWAYS 默认
    //Include.NON_DEFAULT 属性为默认值不序列化
    //Include.NON_EMPTY 属性为 空(“”) 或者为 NULL 都不序列化
    //Include.NON_NULL 属性为NULL 不序列化

    注意:只对VO起作用,Map List不起作用,另外jackson还能过滤掉你设置的属性,具体的就各位自己去研究源码了


    Gson

    3.Google提供的Gson,该gson序列化只与属性(字段)有关,与get开头的方法无关。

    gson和fastjson一样,默认是不序列化null值对应的key的,具体案例如下:
     
    public static void main(String[] args) throws JsonGenerationException, JsonMappingException, IOException {
    AutoPartsSearchRequest request = new AutoPartsSearchRequest();
    request.setKeywords("123");
    request.setSortingField("234242");
    Gson g = new GsonBuilder().create();
    String str = g.toJson(request);
    System.out.println(str);
    //输出结果:{"sortingField":"234242","keywords":"123"}
    }
    若是想序列化null值对应的key,只需要将以上创建代码改成以下代码就行:
    Gson g = new GsonBuilder().serializeNulls().create();

    参考文章:

    1、Java下利用Jackson进行JSON解析和序列化

  • 相关阅读:
    如何在 Microsoft Visual C# .NET 中实现 Microsoft Excel 自动化
    CentOS 6.5静态IP的设置(NAT和桥接都适用)
    myeclipse里如何添加mysql数据库
    Attribute value is quoted with " which must be escaped when used within the value 问题解决
    CentOS 6.5安装之后的网络配置
    Apache server for win解压版的安装与配置
    Oracle SQL 基本操作之 用户权限管理方法
    CentOS 6.5的安装详解
    IO类01
    可见性的问题
  • 原文地址:https://www.cnblogs.com/AlanWilliamWalker/p/11116568.html
Copyright © 2020-2023  润新知