使用 Jackson 仅以毫秒序列化 LocalDateTime
Serialize LocalDateTime with only milliseconds with Jackson
我想将 LocalDateTime
序列化为文本格式,同时只显示毫秒。我尝试了以下示例:
final ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new Jdk8Module());
mapper.registerModule(new JavaTimeModule());
mapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
mapper.disable(SerializationFeature.WRITE_DATE_TIMESTAMPS_AS_NANOSECONDS);
final LocalDateTime t = LocalDateTime.of(2014, 3, 30, 12, 30, 23, 123456789);
System.out.println(mapper.writeValueAsString(t));
这输出:
"2014-03-30T12:30:23.123456789"
所以精度仍然以纳秒为单位,尽管没有按照 mapper.disable(SerializationFeature.WRITE_DATE_TIMESTAMPS_AS_NANOSECONDS)
.
显示它们
我预计:
"2014-03-30T12:30:23.123"
这是为什么?我该如何解决这个问题?
由于您禁用了 WRITE_DATES_AS_TIMESTAMPS,启用或禁用 [=34=] 没有任何作用,因为 localDateTime 不再在时间戳表示中。
如果您启用 WRITE_DATES_AS_TIMESTAMPS 然后禁用 WRITE_DATE_TIMESTAMPS_AS_NANOSECONDS,您将获得所需的结果,但采用另一种形式 ([2014,3,30,12,30,23,123]),因此这也不是一个选择。
所以基本上只有两种方案可以达到预期的效果:
最简单的 - 使用这个:
System.out.println(mapper.writeValueAsString(t.truncatedTo(ChronoUnit.MILLIS)));
(请记住,您可以安全地删除 mapper.disable(SerializationFeature.WRITE_DATE_TIMESTAMPS_AS_NANOSECONDS);
,因为在这种情况下它什么都不做)。
更复杂的方式(不截断时间):
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSS");
SimpleModule simpleModule = new SimpleModule();
simpleModule.addSerializer(new LocalDateTimeSerializer(dateTimeFormatter));
final ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(simpleModule);
final LocalDateTime t = LocalDateTime.of(2014, 3, 30, 12, 30, 23, 123456789);
System.out.println(mapper.writeValueAsString(t));
(在那种情况下,您甚至不需要使用 JavaTimeModule)。
我想将 LocalDateTime
序列化为文本格式,同时只显示毫秒。我尝试了以下示例:
final ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new Jdk8Module());
mapper.registerModule(new JavaTimeModule());
mapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
mapper.disable(SerializationFeature.WRITE_DATE_TIMESTAMPS_AS_NANOSECONDS);
final LocalDateTime t = LocalDateTime.of(2014, 3, 30, 12, 30, 23, 123456789);
System.out.println(mapper.writeValueAsString(t));
这输出:
"2014-03-30T12:30:23.123456789"
所以精度仍然以纳秒为单位,尽管没有按照 mapper.disable(SerializationFeature.WRITE_DATE_TIMESTAMPS_AS_NANOSECONDS)
.
我预计:
"2014-03-30T12:30:23.123"
这是为什么?我该如何解决这个问题?
由于您禁用了 WRITE_DATES_AS_TIMESTAMPS,启用或禁用 [=34=] 没有任何作用,因为 localDateTime 不再在时间戳表示中。
如果您启用 WRITE_DATES_AS_TIMESTAMPS 然后禁用 WRITE_DATE_TIMESTAMPS_AS_NANOSECONDS,您将获得所需的结果,但采用另一种形式 ([2014,3,30,12,30,23,123]),因此这也不是一个选择。
所以基本上只有两种方案可以达到预期的效果:
最简单的 - 使用这个:
System.out.println(mapper.writeValueAsString(t.truncatedTo(ChronoUnit.MILLIS)));
(请记住,您可以安全地删除
mapper.disable(SerializationFeature.WRITE_DATE_TIMESTAMPS_AS_NANOSECONDS);
,因为在这种情况下它什么都不做)。更复杂的方式(不截断时间):
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSS"); SimpleModule simpleModule = new SimpleModule(); simpleModule.addSerializer(new LocalDateTimeSerializer(dateTimeFormatter)); final ObjectMapper mapper = new ObjectMapper(); mapper.registerModule(simpleModule); final LocalDateTime t = LocalDateTime.of(2014, 3, 30, 12, 30, 23, 123456789); System.out.println(mapper.writeValueAsString(t));
(在那种情况下,您甚至不需要使用 JavaTimeModule)。