atitit.解决net.sf.json.JSONException There is a cycle in the hierarchy
1. 环境:使用hibernate4跟个,,要不个哪的对象系列化成个json的时候儿有这个问题了... 1
2. 原因::hb默认的lazy 方式造成的当有关联对象的时候儿... 1
3. #---解决::lazy =false (推荐).. 1
4. 别的有以下的四个方法可以解决hibernate的序列化问题 2
5. BeanUtils.copyProperties 可以解决... 2
9. 设置JSON-LIB的setCycleDetectionStrategy属性让其自己处理循环(ati测试不生效O81).. 4
1. 环境:使用hibernate4跟个,,要不个哪的对象系列化成个json的时候儿有这个问题了...
2. 原因::hb默认的lazy 方式造成的当有关联对象的时候儿...
3. #---解决::lazy =false (推荐)..
<!-- o7o ati -->
<!-- many开头的是代表该表持有外键 -->
<!-- class可以不写,因为根据name的值computer(属性),会通过反射自动找到属于哪个类的 -->
<many-to-one name="prgrm" insert="false" update="false" lazy="false">
<column name="progarmme_id" />
</many-to-one>
作者:: 老哇的爪子 Attilax 艾龙
4. 别的有以下的四个方法可以解决hibernate的序列化问题
1 domain类实现JSONString接口
2 建立JsonConfig实例,并配置属性排除列表
3 用属性过滤器
4 写一个自定义的JsonBeanProcessor
5. BeanUtils.copyProperties 可以解决...
GvProgramme stp=(GvProgramme) arg1;
GvProgramme o=new GvProgramme();
BeanUtils.copyProperties(o, stp);
6. 属性过滤器PropertyFilter
// 先过滤对set集合的拆解 4 JsonConfig config = new JsonConfig(); 5 config.setJsonPropertyFilter(new PropertyFilter() { 6 @Override 7 public boolean apply(Object arg0, String arg1, Object arg2) { 8 if (arg1.equals("shoppingCarts")) { 9 return true;10 } else {11 return false;12 }13 }14 });15 // 将数据转换成Json数据16 JSONArray jsonObject = JSONArray.fromObject(listCarts, config);17 System.out.println(jsonObject.toString());
7. 简单属性过滤器setExclusions法
2.第二种方法通过jsonconfig实例,对包含和需要排除的属性进行方便添加删除
[java]view plaincopyprint
5 public class Person {<br>
6 private String name;<br>
7 private String lastname;<br>
8 private Address address;<br>
9 <br>
10 // getters & setters<br>
11 }<br>
12 <br>
13 JsonConfig jsonConfig = new JsonConfig();<br>
14 jsonConfig.setExclusions( new String[]{ "address" } );<br>
15 Person bean = /* initialize */;<br>
16 JSON json = JSONSerializer.toJSON( bean, jsonConfig );
注意:这种方法不区分目标类,就是说如果有2个bean当中都存在“address”属性,那么采用这种方法,这两个bean中的address属 性都将被排除
3. 使用propertyFilter可以允许同时对需要排除的属性和类进行控制,这种控制还可以是双向的,也可以应用到json字符串到java对象
public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response){
LibtypeDAO libtypeDAO = new LibtypeDAO();
List<Libtype> list = libtypeDAO.findAll();
JsonConfig jsonConfig = new JsonConfig(); //建立配置文件
jsonConfig.setIgnoreDefaultExcludes(false); //设置默认忽略
jsonConfig.setExcludes(new String[]{"libs"}); //此处是亮点,只要将所需忽略字段加到数组中即可,在上述案例中,所要忽略的是“libs”,那么将其添到数组中即可,在实际测试中,我发现在所返回 数组中,存在大量无用属性,如“multipartRequestHandler”,“servletWrapper”,那么也可以将这两个加到忽略数组 中.
8. JsonBeanProcessor法
4. 最后来看JsonBeanProcessor,这种方式和实现JsonString很类似,返回一个代表原来的domain类的合法JSONOBJECT
1.设置JSON-LIB让其过滤掉引起循环的字段:
9. 设置JSON-LIB的setCycleDetectionStrategy属性让其自己处理循环(ati测试不生效O81)..
2.
3.省事但是数据过于复杂的话会引起数据溢出或者效率低下。
public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response){
LibtypeDAO libtypeDAO = new LibtypeDAO();
List<Libtype> list = libtypeDAO.findAll();
JsonConfig jsonConfig = new JsonConfig(); //建立配置文件
jsonConfig.setIgnoreDefaultExcludes(false); //设置默认忽略
jsonConfig.setCycleDetectionStrategy(CycleDetectionStrategy.LENIENT); //此处是亮点,不过经过测试,第2种方法有些悲剧,虽然可以使用,但其结果貌似循环数次,至于为啥,还请高人指点。
JSONArray jsonArray = JSONArray.fromObject(list,jsonConfig); //加载配置文件
return null;
}
3.
10. 参考