报com.fasterxml.jackson.databind.JsonMappingException:Infinite recursion的错误解决方案
在使用jackson依赖包提供的ObjectMapper对象转JSON的过程中报com.fasterxml.jackson.databind.JsonMappingException:Infinite recursion xxx....
的错误,说明在ObjectMapper对象在转JSON时,属性中有调用对象自身的情况出现,会造成无限递归,直到栈溢出的情况,也就是本次出现的异常信息。
解决方案:
1.查看当前对象明显的属性列表中是否含有调用当前对象的情况。
2.查看隐式的属性列表中是否含有调用当前对象的情况。(作者就是这种情况) 其中,日志打印属性也会被算进去,如果含有日志打印属性,则需要在转json的时候排除当前属性,故使用@JsonBackReference
注解即可。
3.直接替换成alibaba的fastjson即可解决。但如果需要修改的地方过多,可能不太适用
作者出现问题的情况:
/*
日志类
*/
public class LoggerObject{
protected Logger logger = Logger.getLogger(this.getClass());
}
/*
转json的对象
*/
public class User extends LoggerObject implements Serializable{
private String name;
private String age;
.....
}
根据当前情况的解决方案:
1.
public class User implements Serializable{
@JsonBackReference
private Logger logger = Logger.getLogger(User.class);
private String name;
private String age;
.....
}
2.
public class LoggerObject{
@JsonBackReference
protected Logger logger = Logger.getLogger(this.getClass());
}