• jackson-databind注解


    jackson中的@JsonBackReference和@JsonManagedReference,以及@JsonIgnore均是为了解决对象中存在双向引用导致的无限递归(infinite recursion)问题。这些标注均可用在属性或对应的get、set方法中。 

    @JsonBackReference    @JsonManagedReference

    经常和@JsonManagedReference通常配对使用,通常用在父子关系中。

    @JsonBackReference标注的属性在序列化(serialization,即将对象转换为json数据)时,会被忽略(即结果中的json数据不包含该属性的内容)。

    @JsonManagedReference标注的属性则会被序列化。

    在序列化时,@JsonBackReference的作用相当于@JsonIgnore,此时可以没有@JsonManagedReference。

    但在反序列化(deserialization,即json数据转换为对象)时,

      如果没有@JsonManagedReference,则不会自动注入@JsonBackReference标注的属性(被忽略的父或子);

      如果有@JsonManagedReference,则会自动注入自动注入@JsonBackReference标注的属性。 

    @JsonIgnore

    @JsonIgnore:作用是进行JSON操作时忽略该属性,以断开无限递归,序列化或反序列化均忽略。当然如果标注在get、set方法中,则可以分开控制,序列化对应的是get方法,反序列化对应的是set方法。

    在父子关系中,当反序列化时,@JsonIgnore不会自动注入被忽略的属性值(父或子),这是它跟@JsonBackReference和@JsonManagedReference最大的区别。

    @JsonIgnoreProperties

    在类的头部统一声明忽略的属性,如:

    @JsonIgnoreProperties({ "extra", "uselessValue" })
    public class Value {
      public int value;
    }

    对于意外的位置属性,也可以忽略

    @JsonIgnoreProperties(ignoreUnknown=true)
    public class PojoWithAny {
      public int value;
    }

    @JsonFormat

    @JsonFormat 此注解用于属性上,作用是把Date类型直接转化为想要的格式,如@JsonFormat(pattern = "yyyy-MM-dd HH-mm-ss")。

    @JsonProperty

     此注解用于属性上,作用是把该属性的名称序列化为另外一个名称,如把trueName属性序列化为name,@JsonProperty("name")。

  • 相关阅读:
    linux权限掩码
    主机跨网通信时的字节序转换
    鸽巢原理-poj3370
    鸽巢原理
    JS面向对象关键词
    Less 命令技巧,从底部网上看
    软件工程概论第七章
    软件工程概论第八章
    软件工程概论第六章
    软件工程概论第五章
  • 原文地址:https://www.cnblogs.com/xiaoQ0725/p/8078807.html
Copyright © 2020-2023  润新知