昨天晚上电商的同事突然找我说在我之前写的那个新运行后台那边除了些问题,说图片加载不出来了,然后我看了下请求返回代码,500了!就跑去看了日志,日志上报了这样的异常
[26/17:31:25 WARN] Failed to write HTTP message: org.springframework.http.converter.HttpMessageNotWritableException: Could not write JSON: null object; nested exception is com.fasterxml.jackson.databind.JsonMappingException: null object (through reference chain: com.zhilehuo.clinic.op.response.ResponseObject$Success["data"]->net.sf.json.JSONObject["recommendationItem"]->net.sf.json.JSONObject["applyUseEnd"])
看起来有点懵,但是从报错信息上可以明确一点就是在JsonObject那里出了问题
然后我拿了最新的代码在本地调试了一次,发现我之前写的这个实体类,同事在下面添加了3个成员变量,其中有两个成员变量的类型是Date类型的,其中有一个就上上面宝座信息里面最后一个名为applyUseEnd的这个成员变量。
调试中,发现JsonObject在将recommendationItem这个对象转为json时,其中Date类型的成员变量就就解析不出来,导致这个对象都无法转化为json对象。
找到是这个原因导致的后,经过度娘看到其他小伙伴们遇到这个问题时用了JsonConfig来帮助json处理Date类型的数据。
package com.zhilehuo.clinic.op.dto;
import lombok.Dat