注解、@JsonIgnore 读写分离, 避免校验和隐藏的冲突问题
Jackson相关:
2、@JsonIgnoreProperties
此注解是类注解,作用是json序列化时将java bean中的一些属性忽略掉,序列化和反序列化都受影响。
3、@JsonIgnore
此注解用于属性或者方法上(最好是属性上),作用和上面的@JsonIgnoreProperties一样。
4、@JsonFormat
此注解用于属性或者方法上(最好是属性上),可以方便的把Date类型直接转化为我们想要的模式,比如@JsonFormat(pattern = "yyyy-MM-dd HH-mm-ss")
5、@JsonSerialize
此注解用于属性或者getter方法上,用于在序列化时嵌入我们自定义的代码,比如序列化一个double时在其后面限制两位小数点。
6、@JsonDeserialize
此注解用于属性或者setter方法上,用于在反序列化时可以嵌入我们自定义的代码,类似于上面的@JsonSerialize
问题场景:
用户注册时, 用户需要填写用户名和密码. 使用spring controller来接收请求数据并验证是否.
对于密码字段, 在实体类中我们增加了
@JsonIgnore
使用此注解, 在转换成json时忽略密码此字段, 避免敏感信息外泄
@NotNull
使用此注解, 要求用户在注册时必须填写密码.
问题原因
前端数据以json格式传递过来时, 由于使用了@JsonIgnore注解, 在做数据校验时获取到的密码为null, 因此无法通过校验.
问题解决
使用@JsonProperty代替@JsonIgnore:
@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
读写分离, 避免校验和隐藏的冲突问题
用户注册时, 用户需要填写用户名和密码. 使用spring controller来接收请求数据并验证是否.
对于密码字段, 在实体类中我们增加了
@JsonIgnore
使用此注解, 在转换成json时忽略密码此字段, 避免敏感信息外泄
@NotNull
使用此注解, 要求用户在注册时必须填写密码.
问题原因
前端数据以json格式传递过来时, 由于使用了@JsonIgnore注解, 在做数据校验时获取到的密码为null, 因此无法通过校验.
问题解决
使用@JsonProperty代替@JsonIgnore:
@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
读写分离, 避免校验和隐藏的冲突问题