版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lp15203883326/article/details/85276346
昨天晚上电商的同事突然找我说在我之前写的那个新运行后台那边除了些问题,说图片加载不出来了,然后我看了下请求返回代码,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.Data;
import net.sf.json.JsonConfig;
import net.sf.json.processors.JsonValueProcessor;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Locale;
/**
* @Author :Lipanpan
* 处理 net.sf.json.JSONObject无法处理java.util.Date格式的对象造成的报错
*/
@Data
public class JsonDateValueProcessor implements JsonValueProcessor {
private String datePattern = "yyy-MM-dd";
public JsonDateValueProcessor(){
super();
}
public JsonDateValueProcessor(String format){
super();
this.datePattern = format;
}
@Override
public Object processArrayValue(Object o, JsonConfig jsonConfig) {
return process(o);
}
@Override
public Object processObjectValue(String s, Object o, JsonConfig jsonConfig) {
return process(o);
}
private Object process(Object value) {
try {
if (value instanceof Date) {
SimpleDateFormat sdf = new SimpleDateFormat(datePattern,
Locale.UK);
return sdf.format((Date) value);
}
return value == null ? "" : value.toString();
} catch (Exception e) {
return "";
}
}
}
写好了后,在这个需要转成json的对象这样写:
JsonConfig jsonConfig = new JsonConfig();
jsonConfig.registerJsonValueProcessor(Date.class,new JsonDateValueProcessor());
RecommendationItem recommendationItem = recommendationItemMapper.getById(itemId);
JSONObject recommendationItemJson = JSONObject.fromObject(recommendationItem,jsonConfig);
这样就成功解决了 net.sf.json.JSONObject无法处理含有java.util.Date格式的对象的问题,也不知道还有没有更好的方法去处理,目前就是这样解决了,如果有更好的方法处理欢迎小伙伴留言告知哦~