关注:CodingTechWork
需求
设计
在开发过程中,有数据一致性校验需求。如下设计:
- 对于一些安全数据进行加密处理,并将这个加密值进行存储。
- 当再次查询时,对当前数据进行加密并比对之前的加密值,看是否一致?若一致,则未被篡改,否则,有篡改风险。
问题
- 某些字段是不需要序列化后加密的,则需要屏蔽掉。
- 时间字段的格式有的序列化为了
"2023-11-30T18:55:32.401"
,有的序列化为了"2023-11-30T18:55:32"
,格式不一致。
序列化问题解决方案
时间字段序列化处理
java
@JsonDeserialize(using = LocalDateTimeDeserializer.class)
@JsonSerialize(using = LocalDateTimeSerializer.class)
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime startTime;
无需序列化字段处理
可以在字段上使用@JSONField
注解进行序列化开关
java
@JSONField(serialize = false)
private String str;
时间一致性序列化统一处理
在使用fastjson
进行序列化时,我们可以使用JSON.toJSONStringWithDateFormat()
方法进行时间格式的统一准换。
java
public <T> String toJsonStr(T t) {
if (t == null) {
return null;
}
try {
String data = JSON.toJSONStringWithDateFormat(t, "yyyy-MM-dd HH:mm:ss");
} catch(Exception e) {
log.error(e)
throw new RuntimeException(e);
}
return data;
}