SSH多表查询对象转json

来源:互联网 发布:橱柜效果图制作软件 编辑:程序博客网 时间:2024/04/30 01:17

最近做的项目是需要把对象转成json传到前台去,实现异步刷新的效果。不巧的是在转化过程中碰到了一些问题,郁闷了好久,在参考别人的意见之前,终于搞定了。哈哈!!!将我的想法记录下来,以做参考之用,贴上部分源码作为理解之用。

     由于Hibernate级联关联关系,使得我们对查询出来的对象进行Json转换的时候失败。要解决这个问题,首先我们需要知道的是在将对象转为Json的时候,是一个怎样的过程(即属性转Json的顺序)。当我们将对象查询出来后,使用fromObject时,解析的过程是这样的,它会以Javabean申明的属性顺序依次转为json。在转换过程中如果碰到了级联关系,那么它就会跳入进去,接着转关联JavaBean属性,因此这个过程就有可能会造成这样的错误(net.sf.json.JSONException: There is a cycle in the hierarchy!),所以说对对象进行转换成json的时候,就需要排除这样的字段。简单的说就是从一个对象开始顺序转,不要让这个过程出现回调的情况。

     接着在我们排除了那些可能会引起 There is a cycle in the hierarchy这样错误字段之后,就可以继续剩余的属性转换了。然后不行的是又出现了其他问题(net.sf.json.JSONException: java.lang.reflect.InvocationTargetException),根据字面上的意思就是说存在一个不能映射的属性,在排查和寻找资料后发现,原来要将对象转为json的条件是属性必须是字符串或者对象,否则都会报刚才的错误,所以这里需要我们对其处理一下,要么就舍弃那些非字符串属性,要么就先处理成字符串然后在转。

   排除了以上的字段后,终于可以转成json了。输出结果如下:

[{"channel":"邮件","operation":{"content":"更新用户目录下lib中的so文件\r\n"..........


我这里使用JsonArray的方法,我想其他的也是类似,就不多说了。如有不对之处,欢迎各位吐槽,我们共同进步!!!微笑

public class User implements Serializable {/** * 序列化,实现对等传输 */private static final long serialVersionUID = 1L;/** * 用户ID */private Integer userId; /** * NT账号 */private String nt;/** * 用户真实姓名 */private String username;/** * 密码 */private String password;/** * 补丁操作表 */private Set<Operation> operations;}


 user. hbm.xml: 

  <set name="operations" inverse = "true" <span style="color:#ff0000;">lazy = "false"</span>>  <key column = "userId" />  <one-to-many class = "Operation"/>   </set>


 切记这里的lazy要设置为false,否则程序会报错。

现在单元测试一下,


Patch pt = patchbiz.queryByPatchId(22);<span style="color:#ff0000;">config.setExcludes(new String[]{"operations","patchSystem","start","end"})</span>;//这里的意思是说把那些会引起级联查询的字段排除,以及不是字符串类型。JSONArray mgs = JSONArray.fromObject(patches, config);System.out.println(mgs);


或者

 config.setJsonPropertyFilter(new PropertyFilter() {        public boolean apply(Object source, String name, Object value) {        if (source instanceof User && name.equals("operations")) {                    return true;               <span style="white-space:pre"></span>else {                    return false;                }        }});<pre name="code" class="html">JSONArray mgs = JSONArray.fromObject(patches, config);System.out.println(mgs);


详情可以参考以下博文内容:

配置JsonConfig过滤有可能引起循环的字段

JsonConfig

JSON--List集合转换成JSON对象




0 0
原创粉丝点击