There is a cycle in the hierarchy

骑猪看日落 2022-03-20 01:24 508阅读 0赞

异常代码如下:

  1. 2019-02-09 12:14:10,221 [http-bio-8082-exec-1] ERROR freemarker.runtime - Template processing error: "Method public java.lang.String org.apache.commons.lang.exception.NestableRuntimeException.getMessage(int) threw an exception when invoked on net.sf.json.JSONException: There is a cycle in the hierarchy!"
  2. Method public java.lang.String org.apache.commons.lang.exception.NestableRuntimeException.getMessage(int) threw an exception when invoked on net.sf.json.JSONException: There is a cycle in the hierarchy!
  3. The problematic instruction:
  4. ----------
  5. ==> ${msgs[0][0]} [on line 76, column 25 in org/apache/struts2/dispatcher/error.ftl]
  6. ----------
  7. Java backtrace for programmers:
  8. ----------
  9. freemarker.template.TemplateModelException: Method public java.lang.String org.apache.commons.lang.exception.NestableRuntimeException.getMessage(int) threw an exception when invoked on net.sf.json.JSONException: There is a cycle in the hierarchy!
  10. at freemarker.ext.beans.SimpleMethodModel.exec(SimpleMethodModel.java:130)
  11. at freemarker.ext.beans.SimpleMethodModel.get(SimpleMethodModel.java:138)
  12. at freemarker.core.DynamicKeyName.dealWithNumericalKey(DynamicKeyName.java:111)
  13. at freemarker.core.DynamicKeyName._getAsTemplateModel(DynamicKeyName.java:90)
  14. at freemarker.core.Expression.getAsTemplateModel(Expression.java:89)
  15. at freemarker.core.Expression.getStringValue(Expression.java:93)
  16. at freemarker.core.DollarVariable.accept(DollarVariable.java:76)
  17. at freemarker.core.Environment.visit(Environment.java:221)
  18. at freemarker.core.MixedContent.accept(MixedContent.java:92)
  19. at freemarker.core.Environment.visit(Environment.java:221)
  20. at freemarker.core.IfBlock.accept(IfBlock.java:82)
  21. at freemarker.core.Environment.visit(Environment.java:221)
  22. at freemarker.core.IfBlock.accept(IfBlock.java:82)
  23. at freemarker.core.Environment.visit(Environment.java:221)
  24. at freemarker.core.MixedContent.accept(MixedContent.java:92)
  25. at freemarker.core.Environment.visit(Environment.java:221)
  26. at freemarker.core.Environment.process(Environment.java:199)
  27. at freemarker.template.Template.process(Template.java:259)
  28. at org.apache.struts2.dispatcher.Dispatcher.sendError(Dispatcher.java:845)
  29. at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:567)
  30. at org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
  31. at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91)
  32. at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
  33. at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
  34. at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:233)
  35. at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
  36. at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
  37. at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
  38. at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
  39. at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
  40. at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:503)
  41. at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
  42. at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
  43. at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950)
  44. at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
  45. at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:421)
  46. at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1070)
  47. at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:611)
  48. at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316)
  49. at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
  50. at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
  51. at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
  52. at java.lang.Thread.run(Thread.java:744)
  53. Caused by: java.lang.NullPointerException
  54. at freemarker.ext.beans.SimpleMemberModel.unwrapArguments(SimpleMemberModel.java:86)
  55. at freemarker.ext.beans.SimpleMethodModel.exec(SimpleMethodModel.java:106)
  56. ... 42 more

在使用JSONObject.fromObject的时候,出现“There is a cycle in the hierarchy”异常。

意思是:层次结构中有一个循环;也就是出现了死循环,也就是Model之间有循环包含关系;

解决办法:

使用setCycleDetectionStrategy防止自包含。

代码如下:

  1. response.setContentType("text/html;charset=UTF-8");
  2. response.setCharacterEncoding("UTF-8");
  3. JsonConfig jc = new JsonConfig();
  4. jc.setCycleDetectionStrategy(CycleDetectionStrategy.LENIENT);
  5. jc.setExcludes(exclude);
  6. JSONArray jsonArray = JSONArray.fromObject(coll, jc);
  7. String result = jsonArray.toString();
  8. try {
  9. response.getWriter().write(result);
  10. } catch (IOException e) {
  11. e.printStackTrace();
  12. }
  13. }

依赖的包:

import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import net.sf.json.JsonConfig;
import net.sf.json.util.CycleDetectionStrategy;

作者:Roger_CoderLife

链接:https://blog.csdn.net/Roger_CoderLife/article/details/86802787

本文为Roger_CoderLife的原创文章,著作权归作者所有,转载请注明原文出处,欢迎转载!

发表评论

表情:
评论列表 (有 0 条评论,508人围观)

还没有评论,来说两句吧...

相关阅读