解决方案,反序列化时进行解析处理
/**
* @Description localDateTime序列化处理解决jpa存储时间数据问题
* @Author space
* @Date 2022/7/26
**/
@Configuration
public class LocalDateTimeSerializerConfig {
@Bean
public Jackson2ObjectMapperBuilderCustomizer jackson2ObjectMapperBuilderCustomizer() {
return builder -> {
//前端需要返回时间戳时可以开启序列化
// builder.serializerByType(LocalDateTime.class, new LocalDateTimeSerializer());
builder.deserializerByType(LocalDateTime.class, new LocalDateTimeDeserializer());
};
}
/**
* 序列化
*/
public static class LocalDateTimeSerializer extends JsonSerializer<LocalDateTime> {
@Override
public void serialize(LocalDateTime value, JsonGenerator gen, SerializerProvider serializers)
throws IOException {
if (value != null) {
long timestamp = value.toInstant(ZoneOffset.ofHours(8)).getEpochSecond();
gen.writeNumber(timestamp);
}
}
}
/**
* 反序列化,接收前端参数及数据库数据返回时均需要进行反序列化处理
*/
public static class LocalDateTimeDeserializer extends JsonDeserializer<LocalDateTime> {
@Override
public LocalDateTime deserialize(JsonParser p, DeserializationContext deserializationContext)
throws IOException {
String dateStr = p.getValueAsString();
//当前端传字符串类型时处理
if ( !Objects.isNull(dateStr)&&dateStr.contains("-")){
return LocalDateTime.parse(dateStr, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
}
//当前端传时间戳类型时处理
long timestamp = p.getValueAsLong();
if (timestamp > 0) {
return LocalDateTime.ofInstant(Instant.ofEpochSecond(timestamp), ZoneOffset.ofHours(8));
} else {
return null;
}
}
}
}