将具有关联关系的两个表通过hibernate从数据库中查出来后转成Json对象时报错解决:采用过滤器

将具有关联关系的两个表通过hibernate从数据库中查出来后转成Json对象时报错解决:采用过滤器

 有一个A表,和B表,是one to many的关系。当我将B表从数据库中查出后.

 通过:

  1. JSONArray responseJsonMsgs=JSONArray.fromObject(list);

转成Json对象时报错:    There is a cycle in the hierarchy!

 

稍微想想就能明白,这里产生了死循环查询(跟hibernate的配置文件有关)。

 

解决方案,在转成Json对象的时候过滤掉bean中引起死循环查询的属性(一般为设置的外键)。

 

  我这里写了一个通用的过滤器对象,大家可以借鉴下

 

  1. package com.cfc.web.msgcenter;
  2. import net.sf.json.JsonConfig;
  3. import net.sf.json.util.PropertyFilter;
  4. public class JsonFilter {
  5.     public static JsonConfig getFilter(final String[] s){
  6.         JsonConfig config = new JsonConfig();
  7.         config.setJsonPropertyFilter(new PropertyFilter(){
  8.             
  9.             public boolean apply(Object source, String name, Object value) {
  10.              if(juge(s,name)) {
  11.               return true;
  12.              } else {
  13.               return false;
  14.              }
  15.             }
  16.             
  17.             public boolean juge(String[] s,String s2){
  18.                 boolean b = false;
  19.                 for(String sl : s){
  20.                     if(s2.equals(sl)){
  21.                         b=true;
  22.                     }
  23.                 }
  24.                 return b;
  25.             }
  26.            });
  27.         return config;
  28.     }
  29. }

 

转换的时候调用过滤器

  1. JsonConfig config = JsonFilter.getFilter(new String[]{"gameclass"});//String数组中存储的是要过滤的属性
  2. JSONArray responseJsonMsgs=JSONArray.fromObject(list,config);

问题解决! 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值