json过滤某些属性之@jsonignore

使用Jackson相关的注解时一定要注意自己定义的属性命名是否规范。
命名不规范时会失去效果。(例如Ename ,Eage 为不规范命名。“nameE”,“ageE”为规范命名)我在此处掉坑半个小时。至于命名规范,大家自己搜索。其实不要太奇葩的命名都是可以的。

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

1、@JsonIgnoreProperties

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

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

//生成json时将name和age属性过滤
@JsonIgnoreProperties({"name","age"})
public class  user {
private  String name;
private int age;
}

2、@JsonIgnore

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

@JsonIgnore   //在json序列化时将java bean中的一些属性忽略掉,序列化和反序列化都受影响
private String password;// 密码

@JsonIgnore这一注解,于是我对这一注解进行了查看,发现这一注解的作用,是在json序列化时,将java bean中的一些属性忽略掉,可以使用在属性或方法上,比如我的项目中把它用在了getter方法上,产生的效果就是当响应某个user对象时,就不会把密码字段响应出去;但是会有一个问题,这样一来,当使用@RequestBody接收json格式的user对象时,会把password字段也忽略掉,这不是我想要的

问题解决:在相应的setter方法上加上@JsonProperty注解即可

3、@JsonFormat

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

4、@JsonSerialize

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

5、@JsonDeserialize

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

6、@Transient

ORM框架将忽略该属性;
如果一个属性并非数据库表的字段,就务必将其标示为@Transient,否则ORM框架默认其注解为@Basic;

    @Transient//数据库映射时忽略的字段
    private Integer stock;// 库存

使用@JsonIgnore遇到的问题

猜你喜欢

转载自blog.csdn.net/qq_42848910/article/details/106440204