解决Jsonwriter发生的Positioned Update not supported问题

      这篇文章其实早在做触动商城的时候已经想写了,不过一直空不出时间和心情来。

      有一次用jsonplugin输出json的时候,发生了以下异常:java.sql.SQLException: Positioned Update not supported,其实以前也遇到过这种问题,原因也找到了,是因为我们生成json的类是hibernate的model类,当中有一些对象是延迟加载的,这些对象并不是原model类中的属性,而是由cglib这个字节码生成器动态生成的对象。Hibernate在这个子类中添加了hibernateLazyInitializer等等的附加属性。由于jsonplugin并不区分类和动态生成的类,所以也会试图序列化hibernateLazyInitializer属性,从而导致出现上述的异常。

       以前项目时间紧急,采用了治标不治本的紧急应对方法:将那些延迟加载的对象都用一个默认构造方法的对象来代替,但这样不利用复用。

       在网上以Positioned Update not supported为关键字搜索了一下,发现了一篇很有用的文章,文本也提到这个问题,并给出了解决方法。不过我却发现文本提到的jsonplugin和我们项目中使用的jsonplugin有些地方不太相同,但它的思路都是一样的。沿用这个思路应该就可以解决问题了。

       思路如下:

1、判断这个对象是否由cglib生成的。代码如下:

boolean isCreateByCGLIB = clazz.getName().indexOf("$$EnhancerByCGLIB$$") > -1 ? true : false;

如果此对象确实是由cglib生成的,那么我们取此对象的基类,这一步很关键,因为通过取得此对象的基类,我们就忽略了所有由cglib生成的跟hibernate相关的属性。

2、通过反射,取得此对象的所有继续于基类的属性。

3、通过反射,取得此对象的所有get方法器(这一步不能省,不然出来的属性就少了)。

4、输出json。

问题解决,开源的力量就是伟大。

你可能感兴趣的:(sql,Hibernate,json)