java json返回数据不全

线上更新部署后出现JSON返回数据不全,前端页面无法显示数据的问题。更新内容包含将实体属性改为懒加载。排查过程中,先排除了nginx问题,又对懒加载进行测试也无果,最终调试代码发现接口转换JSON时有空指针错误,且错误隐蔽未报入日志文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

起因

线上经过一次更新部署后莫名出现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;
	}
最后问题解决

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值