美文网首页
Jackson格式化与Json传输

Jackson格式化与Json传输

作者: 榷奕 | 来源:发表于2019-07-23 15:26 被阅读0次

    1. Jackson时间格式化

    (1)导包

    Jackson的那几个依赖包在spring-boot-starter-web这个依赖里面已经有了,所以不需要额外导包。

    (2)在yml里面写配置开启

    /*
    重要的一句,这里应该是只有yml格式开启格式化不能使用LocalDateTime类,如果手动打注解那使用那种类都无所谓。
    */
    使用这种全局配置的办法,需要在数据库里面使用timestamp格式,java实体类里面使用Date类(在这里要注意的就是如果java里面用了LocalDateTime这种东西就不好用)。

    spring:
        jackson:
            date-format:  yyyy-MM-dd 
            time-zone: GMT+8
    
    (3)使用注解的方式
    @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
    

    因为包已经导了,所以基本伤用这个办法的话就打一个注解就完了。
    这个注解打在域上面或者打在get方法上面都行,这两个只要有一个就行了。

    (4) 还差一种全局设置LocalDate的方法

    2. 用Jackson解决null的问题

    (1)用yml能解决的问题

    时间的格式化可以用yml解决
    如果返回值里面有null、空串""的话可以把这个属性去掉
    效果如下:



    直接就把这个属性从Json字符串里面删掉了

    spring:
      jackson:
        #日期格式化
        date-format: yyyy-MM-dd HH:mm:ss
        serialization:
           #格式化输出 
          indent_output: true
          #忽略无法转换的对象
          fail_on_empty_beans: false
        #设置空如何序列化
        defaultPropertyInclusion: NON_EMPTY
        deserialization:
          #允许对象忽略json中不存在的属性
          fail_on_unknown_properties: false
        parser:
          #允许出现特殊字符和转义符
          allow_unquoted_control_chars: true
          #允许出现单引号
          allow_single_quotes: true
    
    (2)要自己重写一个bean解决的

    主要是如果要保留这个null的字段,把null变成"",这样可能就要手写bean了。

    @Bean
    @Primary
    @ConditionalOnMissingBean(ObjectMapper.class)
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder)
        {
            ObjectMapper objectMapper = builder.createXmlMapper(false).build();
    
            // 通过该方法对mapper对象进行设置,所有序列化的对象都将按改规则进行系列化
            // Include.Include.ALWAYS 默认
            // Include.NON_DEFAULT 属性为默认值不序列化
            // Include.NON_EMPTY 属性为 空("") 或者为 NULL 都不序列化,则返回的json是没有这个字段的。这样对移动端会更省流量
            // Include.NON_NULL 属性为NULL 不序列化
            objectMapper.setSerializationInclusion(JsonInclude.Include.NON_EMPTY);
            objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
            // 允许出现特殊字符和转义符
            objectMapper.configure(JsonParser.Feature.ALLOW_UNQUOTED_CONTROL_CHARS, true);
            // 允许出现单引号
            objectMapper.configure(JsonParser.Feature.ALLOW_SINGLE_QUOTES, true);
            // 字段保留,将null值转为""!!!!!
            objectMapper.getSerializerProvider().setNullValueSerializer(new JsonSerializer<Object>()
            {
                @Override
                public void serialize(Object o, JsonGenerator jsonGenerator,
                                      SerializerProvider serializerProvider)
                        throws IOException
                {
                    jsonGenerator.writeString("");
                }
            });
            return objectMapper;
        }
    

    3. Json格式

    首先Json格式分成了Json字符串和Json对象两种
    前后端传输的时候用的是Json字符串,比较节约带宽看着也舒服,Json字符串可以理解成序列化之后的结果之一吧。
    而传输的时候用Json字符串,那Json字符串和Json对象的转化就相当重要,传输完了之后,一接到这个字符串就转换成Json对象。

    4. 序列化

    (1)序列化的两种方式

    Serializable原生的方式实现序列化和Json传输实现序列化两种方式。
    如果从广义上理解序列化,只要把对象写到文件里面去,并且从文件里面恢复出对象来,就实现了序列化与反序列化。
    Serializable这个,就把对象序列化成二进制形式。
    Json格式就把对象存成了字符串形式,反正都是能反序列化回去的。

    (2)Serializable形式

    这里面有一个serialVersionUID。这个id是用对象里面的属性,通过哈希运算算出来的值,因为序列化一般用在两台服务器之间传输,两个服务之间传输,反正就是要在这边建一个类,对面也要建一个一样的类这种场景下的。
    那就要保证这两个类完全一致,如果自己不手动在两个类里面加这个id,jvm要通过这个类里面的属性名帮你去运算出这个id然后比较。那有一点儿不一样可能就出问题,所以有时候自己定义一个1L默认值,其实这值没啥讲究,两边一样就行。

    相关文章

      网友评论

          本文标题:Jackson格式化与Json传输

          本文链接:https://www.haomeiwen.com/subject/xnnolctx.html