以客户(一方) 对 联系人(多方) 为例。
public class Customer {
private Long cust_id;
private String cust_name;
//一方上配置set
@JSONField(serialize=false) //避免转json的时候死循环
private Set<Linkman> linkmans =new HashSet<Linkman>();
}
public class Linkman {
private Long lkm_id;
private String lkm_name;
//多方维护一方的外键
private Customer customer;
当使用fastjson来封装Customer的时候,由于Customer内部有Linkman的set集合,所以会把Linkman也一起解析成json,而Linkman里面又有Customer,所以又会把Customer进行解析,这样就造成了死循环了。
解决办法就是在Customer 类的linkmans 属性上加上一句@JSONField(serialize=false)
这样当Customer转json的时候就会忽略Linkman了.
另外,fastjson还有一个循环引用的问题,就是当把List转成jsonArray的时候,如果List中的对象存在相同的,它会用符号来标识,而不转成JSONObject
解决办法就是,在调用JSON.toJSONString()方法的时候,在第二个参数传入SerializerFeature.DisableCircularReferenceDetect即可.
下面是对fastjson的简单封装的工具类
package blog.csdn.net.mchenys.utils;
import java.io.IOException;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletResponse;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;
public class FastJsonUtil {
/**
* 将对象转成json串
*
* @param object
* @return
*/
public static String toJSONString(Object object) {
// DisableCircularReferenceDetect来禁止循环引用检测
return JSON.toJSONString(object, SerializerFeature.DisableCircularReferenceDetect);
}
// 输出json
public static void write(HttpServletResponse response, Object object) {
response.setContentType("application/json;utf-8");
response.setCharacterEncoding("UTF-8");
try {
response.getWriter().print(toJSONString(object));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}