起因
线上经过一次更新部署后莫名出现json返回数据不全,导致前端页面显示不出来数据,如图:
注:更新内容有一项是把实体的属性改成懒加载。
起初
1、以为是nginx,设置了响应数据的长度。绕过了nginx直接访问了tomcat,发现还是有问题。排除了nginx。
2、以为是懒加载的问题,因为项目更新中含有这些内容。
在配置文件中增加了
#配置就是在controller层就打开EntityManager,由controller层控制session的开启和关闭,这样controller层就可以操作对象,而不会出现no session
spring.jpa.open-in-view=true
#在没有事务的情况下允许懒加载
spring.jpa.enable_lazy_load_no_trans=true
结果没有用
3、后来调试代码时,发现接口返回在转换json时报错了,空指针错误,猜测应该时某个属性空了(或许是因为懒加载的原因导致的)。
只不过这个错误根本没有报错到日志文件,只输出了一行信息,非常隐蔽。不细看根本不知道后台已经报错了(因为前台有返回数据)
因为项目使用的springboot默认的jackson,所以配置了:
objectMapper.disable(SerializationFeature.FAIL_ON_EMPTY_BEANS);//序列化时忽略无法转换的bean
全部代码如下:
public MappingJackson2HttpMessageConverter getMappingJackson2HttpMessageConverter() {
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.disable(DeserializationFeature.FAIL_ON_IGNORED_PROPERTIES);
objectMapper.disable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);
objectMapper.disable(SerializationFeature.FAIL_ON_EMPTY_BEANS);//序列化时忽略无法转换的bean
SimpleModule simpleModule = new SimpleModule();
simpleModule.addSerializer(Date.class, new DateJsonSerializer());
simpleModule.addDeserializer(Date.class, new DateJsonDserializer());
objectMapper.registerModule(simpleModule);
MappingJackson2HttpMessageConverter sc = new MappingJackson2HttpMessageConverter();
sc.setObjectMapper(objectMapper);
return sc;
}
最后问题解决