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

6. 属性过滤器PropertyFilter 2

7. 简单属性过滤器setExclusions法 3

8. JsonBeanProcessor法 4

9. 设置JSON-LIB的setCycleDetectionStrategy属性让其自己处理循环(ati测试不生效O81).. 4

10. 参考 5

 

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. 参考