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 艾龙,  EMAIL:1466519819@qq.com

转载请注明来源: http://blog.csdn.net/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 plain​​​​copy​​​​print​​​​?​

 

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.