Jackson 常用注解

Jackson相关:
使用Jackson相关的注解时一定要注意自己定义的属性命名是否规范。 一般我们使用驼峰命名法(firstName)

如果使用@JsonIgnore注解不起效时请注意一下你的属性名字是否规范

1、@JsonIgnoreProperties

此注解是类注解,作用是json序列化时将java bean中的一些属性忽略掉,序列化和反序列化都受影响。

写法将此标签加在model 类的类名上 ,可以多个属性也可以单个属性

//生成json时将name和age属性过滤

@JsonIgnoreProperties({”name","age","title"})
public class  user {
        private  String name;
        private int age;
}

2、@JsonIgnore

此注解用于属性或者方法上(最好是属性上),作用和上面的@JsonIgnoreProperties一样。

生成json 时不生成age 属性

public class user { 
        private String name; 
        @JsonIgnore 
        private int age; 
} 

3、@JsonFormat

此注解用于属性或者方法上(最好是属性上),可以方便的把Date类型直接转化为我们想要的模式,比如@JsonFormat(pattern = “yyyy-MM-dd HH-mm-ss”)

4、@JsonSerialize

此注解用于属性或者getter方法上,用于在序列化时嵌入我们自定义的代码,比如序列化一个double时在其后面限制两位小数点。

5、JsonView
视图模板,作用于方法和属性上,用来指定哪些属性可以被包含在JSON视图中

6、@JsonDeserialize

此注解用于属性或者setter方法上,用于在反序列化时可以嵌入我们自定义的代码,类似于上面的@JsonSerialize

7、@Transient(Hibernate的一个注释)
实体类中,若定义一个属性,在它的get/set方法上,使用@Transient时,则数据库没有对应的字段与之对应,仅仅是一个临时变量
如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则ORM框架默认其注解为@Basic;

8、@JsonSubTypes
作用于类/接口,用来列出给定类的子类,只有当子类类型无法被检测到时才会使用它,一般是配合@JsonTypeInfo在基类上使用

猜你喜欢

转载自blog.csdn.net/qq_36521579/article/details/79768388