net.sf.json.JSONException: There is a cycle in the hierarchy!

写篇经验贴睡觉折腾了我4个小时,说多了都是泪。为了看到的人以后不流泪,熬夜到1点我也要写出来

net.sf.json.JSONException: There is a cycle in the hierarchy!
    net.sf.json.util.CycleDetectionStrategy$StrictCycleDetectionStrategy.handleRepeatedReferenceAsArray(CycleDetectionStrategy.java:69)
    net.sf.json.JSONArray._fromCollection(JSONArray.java:823)
    net.sf.json.JSONArray.fromObject(JSONArray.java:137)
    net.sf.json.JSONObject._processValue(JSONObject.java:2402)
    net.sf.json.JSONObject._setInternal(JSONObject.java:2447)
    net.sf.json.JSONObject.setValue(JSONObject.java:1189)
    net.sf.json.JSONObject._fromBean(JSONObject.java:725)
    net.sf.json.JSONObject.fromObject(JSONObject.java:182)
    net.sf.json.JSONObject._processValue(JSONObject.java:2426)
    net.sf.json.JSONObject._setInternal(JSONObject.java:2447)
    net.sf.json.JSONObject.setValue(JSONObject.java:1189)
    net.sf.json.JSONObject._fromBean(JSONObject.java:725)
    net.sf.json.JSONObject.fromObject(JSONObject.java:182)
    net.sf.json.JSONObject._processValue(JSONObject.java:2426)
    net.sf.json.JSONObject._setInternal(JSONObject.java:2447)
    net.sf.json.JSONObject.setValue(JSONObject.java:1189)
    net.sf.json.JSONObject._fromBean(JSONObject.java:725)
    net.sf.json.JSONObject.fromObject(JSONObject.java:182)
    net.sf.json.JSONObject._processValue(JSONObject.java:2426)
    net.sf.json.JSONObject._setInternal(JSONObject.java:2447)
    net.sf.json.JSONObject.setValue(JSONObject.java:1189)
    net.sf.json.JSONObject._fromBean(JSONObject.java:725)
    net.sf.json.JSONObject.fromObject(JSONObject.java:182)
    net.sf.json.JSONArray._processValue(JSONArray.java:2294)
    net.sf.json.JSONArray.processValue(JSONArray.java:2325)
    net.sf.json.JSONArray.addValue(JSONArray.java:2312)
    net.sf.json.JSONArray._fromCollection(JSONArray.java:841)
    net.sf.json.JSONArray.fromObject(JSONArray.java:137)
    net.sf.json.JSONObject._processValue(JSONObject.java:2402)
    net.sf.json.JSONObject._setInternal(JSONObject.java:2447)
    net.sf.json.JSONObject.setValue(JSONObject.java:1189)
    net.sf.json.JSONObject._fromBean(JSONObject.java:725)
    net.sf.json.JSONObject.fromObject(JSONObject.java:182)
    net.sf.json.JSONArray._processValue(JSONArray.java:2294)
    net.sf.json.JSONArray.processValue(JSONArray.java:2325)
    net.sf.json.JSONArray.addValue(JSONArray.java:2312)
    net.sf.json.JSONArray._fromCollection(JSONArray.java:841)
    net.sf.json.JSONArray.fromObject(JSONArray.java:137)
    com.sun.action.UserInfoAction.findUserinfoAll(UserInfoAction.java:81)
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    java.lang.reflect.Method.invoke(Method.java:597)
    com.opensymphony.xwork2.DefaultActionInvocation.invokeAction(DefaultActionInvocation.java:452)
    com.opensymphony.xwork2.DefaultActionInvocation.invokeActionOnly(DefaultActionInvocation.java:291)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:254)
    com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:176)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:263)
    org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:68)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:133)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:207)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:207)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:190)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    org.apache.struts2.interceptor.MultiselectInterceptor.intercept(MultiselectInterceptor.java:75)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:94)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:243)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:100)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:141)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:267)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:142)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.PrepareInterceptor.doIntercept(PrepareInterceptor.java:166)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:176)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:164)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:190)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:187)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:248)
    org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
    org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:485)
    org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
    org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91)
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198)
    org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)

这是使用hibernate+Spring+Struts2时报的错,具体说的是我在把List对象集合转成JSon时报错,明眼人一看就知道,死循环了……原因就是我取值的这个对象很复杂关联了N个对象(表),N个对象(表)又关联它

4个小时的成果分享,我想说才开始时报的不是这个错/(ㄒoㄒ)/~~,
第一次报的是Sesson关闭,具体原因是session没等我会话结束就关闭了,取值你时……掰着脚趾头都能想到O(∩_∩)O~,我就把session关闭时间延长具体代码

1.在加入这个FILETER的时候,一定一定,千万千万记得放在STRUTS2的核心控制器的位置的上面!切记!
2.如果你的SPRING的配置文件中SessionFactory的BEAN ID默认不是sessionFactory的话,你的openSessionInView要改成这样.
<filter>
   <filter-name>openSessionInView</filter-name>
   <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
   <init-param>
    <param-name>sessionFactoryBeanName</param-name>
    <param-value>sessionFactory</param-value><!--//这里的值是取决于你在bean.xml中的配置的名称的
   --></init-param>
  </filter>

  <filter-mapping>
   <filter-name>openSessionInView</filter-name>
   <url-pattern>/*</url-pattern>
  </filter-mapping>

加了之后呢,继续错,苦逼了吧

当你把OPENSESSIONINVIEW配置上后,你就可以让SESSION晚点关闭的.但是又一个新的问题产生了.什么问题呢?自己可以试试,如果这个时候你的SPRING
没有配置事务的话,那么你所有的更新操作都是不允许的.
所以要在SPRING里把需要更新的SERVICE操作都配置事务.

ok加事务

配置如下:
首先在SPRING配置文件中加入XML命名空间:
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
方案地址:
xsi:schemaLocation里加上
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd"
前提是你配置了AOP的命名空间和方案地址
<!-- 事务配置 -->

<!--Step1.事务管理器配置-->
    <bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
    </bean>

    <!--Step2.交给SPRING事务管理的一些方法.-->
    <aop:config>
        <aop:pointcut id="productServiceMethods"
            <!-- 指定切面是哪个范围类,比如你项目的SERVICE的所有方法-->
            expression="execution(* com.公司名.项目名.service..*.*(..))" />
        <!-- 一个通知的集合,这个集合都用上的POINTCUT-->
        <aop:advisor advice-ref="txAdvice"
            pointcut-ref="productServiceMethods" />
    </aop:config>
    <!--定义通知集合,以TX开头,是有事务的 -->
    <tx:advice id="txAdvice" transaction-manager="txManager">
        <tx:attributes>
        <!--所有的以ADD开头的方法名的方法都用事务  REQUIRED 表示,比如方法A有更新操作,A中调用了B方法,那么B到底是重新起一个事务还是用A方法的事务,
        REQUIRED标识不起就用当前事务,如果有就用A的,如果没有就起一个-->
            <tx:method name="add*" propagation="REQUIRED" />
            <tx:method name="delete*" propagation="REQUIRED" />
            <tx:method name="update*" propagation="REQUIRED" />
            <!--加入只读,说明以GET或者LOAD开头的方法名的方法都是只读事务,说明这个方法内没有UPDATE操作,这样声明下可以提高该查询方法的效率 -->
            <tx:method name="get*" propagation="REQUIRED"
                read-only="true" />
            <tx:method name="load*" propagation="REQUIRED"
                read-only="true" />
        </tx:attributes>
    </tx:advice>

此时我以为问题会到此终结,结果证明我异想天开。
好了,不扯了回归正题,怎么解决复杂的集合对象转成json呢。

//根据页数和行数查出数据
         userinfoList=userInfoServices.findUserInfoAll(page, rows);
        //总行数
        int count=userInfoServices.findUserinfoCount();
        //转成json
        JsonConfig cfg = new JsonConfig();
        //这里是把关联对象剔除掉
       cfg.setJsonPropertyFilter(new PropertyFilter()
        {
             public boolean apply(Object source, String name, Object value) {
               if(name.equals("tbDepartment")||name.equals("tbOrders")||name.equals("tbUserinfoRoles")||name.equals("tbCommisions")) {
                 return true;
               } else {
                 return false;
              }
            }
           }); 
          JSONArray jsonArray = JSONArray.fromObject(userinfoList,cfg);  //加载配置文件

        System.out.print("[{total:"+count+",rows:"+jsonArray.toString()+"}]");  

希望能帮到你晚安。。。。
最后附上我的漂亮界面这里写图片描述

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

智海深渊

对您有帮助给点鼓励吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值