解决LocalDateTime返回到前端变为时间戳(序列化与反序列化)@JsonFormat失效等问题

问题描述:实体类实现了Serializable接口,实体类中有一个LocalDateTime类型的属性,用@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss")注解进行修饰,且application.properties中配置了

spring.jackson.serialization.write_dates_as_timestamps=false,但是前端收到的对象中的时间是时间戳格式

最终百度之后在config中的Mybaitis配置文件中添加了一个Bean

@Bean
public ObjectMapper serializingObjectMapper() {
  ObjectMapper objectMapper = new ObjectMapper();
  objectMapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
  objectMapper.registerModule(new JavaTimeModule());
  return objectMapper;
}

返回了时间格式的字符串

但是后面梳理发现在config目录下的SpringConfig中有下面一段

@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.atZone(ZoneId.systemDefault()).toInstant().toEpochMilli();
				gen.writeNumber(timestamp);
			}
		}
	}

	/**
	 * 反序列化
	 */
	public static class LocalDateTimeDeserializer extends JsonDeserializer<LocalDateTime> {
		@Override
		public LocalDateTime deserialize(JsonParser p, DeserializationContext deserializationContext)
				throws IOException {
			long timestamp = p.getValueAsLong();
			if (timestamp > 0) {
				return LocalDateTime.ofInstant(Instant.ofEpochMilli(timestamp), ZoneId.systemDefault());
			} else {
				return null;
			}
		}
	}

去掉我写的Bean和这个序列化的这个bean就正确了

分析原因如下:涉及spring配置文件的加载顺序及ObjectMapper应用

首先    分析为什么没有加serializingObjectMapper之前配置文件中的配置没有生效,因为按照配置文件的加载顺序,先加载根目录下的application.properties,然后加载config目录下的其他文件,SpringConfig配置文件中的序列化与反序列化处理的LocalDateTime是返回时间戳,对application.properties文件中的配置进行了覆盖

其次加入serializingObjectMapper之后,应该是先加载我写的MybatisConfig这个配置,再加载SpringConfig中这个配置,为什么没有覆盖我的配置

原因是

SpringConfig中配置的是默认的,我写在MybatisConfig中的是自定义的,优先级会高一点,不会 对其进行覆盖

其实通过debug也可以发现

没有执行到if判断这一行项目就开始运行了

注:可以根据下面的方法进行配置文件加载优先级的测试

@Bean

public TomcatServletWebServerFactory servletContainer(){undefined

return new TomcatServletWebServerFactory(8081) ;

}

 

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值