主要是解决JSON因Hibernate映射生成的集合的转化出现的死循环问题。

这个方法很重要

     public String ajaxJsonByObjectDirecdt(Object obj, String[] filterNames){
         JsonConfig jsonConfig = new JsonConfig();
         jsonConfig.setIgnoreDefaultExcludes(false);
         jsonConfig.setCycleDetectionStrategy(CycleDetectionStrategy.LENIENT);    //防止自包含

         if(filterNames != null){
             //这里是核心,过滤掉不想使用的属性
             jsonConfig .setExcludes(filterNames) ;
         }
         JSONObject jsonObj = JSONObject.fromObject(obj, jsonConfig);
         //ajax()方法主要功能是将数据通过输出流输出到Client
         return ajax(jsonObj.toString(), "text/html");

     }
对于参数,String[] filterNames,这个字符串数组中存放的是变量的名字(句柄),而不是变量的类型。
     public String getUserLoginInfo(){
         User user = (User)getSession().getAttribute(USER);
                 //要过滤的属性集合
         String[] filterNames =
                 new String[]{"role", "operatingHistories", "helpInfoBoards", "replyInfos",
                 "helpInfos", "credits", "users", "user",
                 "helpInfoBoard"};

         return ajaxJsonByObjectDirecdt(user, filterNames);
     }

其中User类含有以下属性:

 public class User implements java.io.Serializable {

     // Fields

     private String id;
     private Role role;
     private String username;
     private String studentNum;
     private String address;
     private Integer age;
     private String nickname;
     private String sex;
     private String qq;
     private String phonenumber;
     private String fixedTelephone;
     private String password;
     private Timestamp registerDate;
     private String imgUrl;
     private String email;
     private String question;
     private String answer;
     private Timestamp totalOnlineDate;
     private Set<OperatingHistory> operatingHistories = new HashSet<OperatingHistory>(
             0);
     private Set<HelpInfoBoard> helpInfoBoards = new HashSet<HelpInfoBoard>(0);
     private Set<ReplyInfo> replyInfos = new HashSet<ReplyInfo>(0);
     private Set<HelpInfo> helpInfos = new HashSet<HelpInfo>(0);
     private Set<Credit> credits = new HashSet<Credit>(0);

       //more methods.
 }
两端代码参照下,就知道怎么使用了。

后台异常信息:

 INFO  com.opensymphony.xwork2.config.ConfigurationManager
 Detected container provider org.apache.struts2.convention.ClasspathConfigurationProvider@67b0eb2c needs to be reloaded.  Reloading all providers.
 INFO  com.opensymphony.xwork2.config.ConfigurationManager
 Detected package provider org.apache.struts2.convention.ClasspathConfigurationProvider@67b0eb2c needs to be reloaded.  Reloading all providers.
 INFO  com.opensymphony.xwork2.config.ConfigurationManager
 Detected package provider org.apache.struts2.convention.ClasspathConfigurationProvider@31af5c3 needs to be reloaded.  Reloading all providers.
 INFO  com.opensymphony.xwork2.config.ConfigurationManager
 Detected package provider org.apache.struts2.convention.ClasspathPackageProvider@5efcd6cc needs to be reloaded.  Reloading all providers.
 INFO  com.opensymphony.xwork2.config.providers.XmlConfigurationProvider
 Parsing configuration file [struts-default.xml]
 INFO  com.opensymphony.xwork2.config.providers.XmlConfigurationProvider
 Parsing configuration file [struts-plugin.xml]
 INFO  com.opensymphony.xwork2.config.providers.XmlConfigurationProvider
 Parsing configuration file [struts.xml]
 INFO  com.opensymphony.xwork2.config.impl.DefaultConfiguration
 Overriding property struts.i18n.reload - old value: false new value: true
 INFO  com.opensymphony.xwork2.config.impl.DefaultConfiguration
 Overriding property struts.configuration.xml.reload - old value: false new value: true
 INFO  org.apache.struts2.config.BeanSelectionProvider
 Loading global messages from i18n
 INFO  org.apache.struts2.spring.StrutsSpringObjectFactory
 Initializing Struts-Spring integration...
 INFO  com.opensymphony.xwork2.spring.SpringObjectFactory
 Setting autowire strategy to name
 INFO  org.apache.struts2.spring.StrutsSpringObjectFactory
 ... initialized Struts-Spring integration successfully
 2014-06-03 01:07:12 Test: Reloading class 'student.life.support.platform.action.BaseAction'.
 hql:from student.life.support.platform.model.User as model where model.username = ?
 Hibernate:
     select
         user0_.id as id62_,
         user0_.address as address62_,
         user0_.age as age62_,
         user0_.answer as answer62_,
         user0_.email as email62_,
         user0_.fixed_telephone as fixed6_62_,
         user0_.img_url as img7_62_,
         user0_.nickname as nickname62_,
         user0_.password as password62_,
         user0_.phonenumber as phonenu10_62_,
         user0_.qq as qq62_,
         user0_.question as question62_,
         user0_.register_date as register13_62_,
         user0_.role_id as role18_62_,
         user0_.sex as sex62_,
         user0_.student_num as student15_62_,
         user0_.total_online_date as total16_62_,
         user0_.username as username62_
     from
         studentlifesupportplatform.user user0_
     where
         user0_.username=?
 WARN  net.sf.json.JSONObject
 Property 'handler' has no read method. SKIPPED
 Hibernate:
     select
         role0_.id as id61_0_,
         role0_.role_permissions as role2_61_0_,
         role0_.role_type as role3_61_0_
     from
         studentlifesupportplatform.role role0_
     where
         role0_.id=?
 Hibernate:
     select
         users0_.role_id as role18_1_,
         users0_.id as id1_,
         users0_.id as id62_0_,
         users0_.address as address62_0_,
         users0_.age as age62_0_,
         users0_.answer as answer62_0_,
         users0_.email as email62_0_,
         users0_.fixed_telephone as fixed6_62_0_,
         users0_.img_url as img7_62_0_,
         users0_.nickname as nickname62_0_,
         users0_.password as password62_0_,
         users0_.phonenumber as phonenu10_62_0_,
         users0_.qq as qq62_0_,
         users0_.question as question62_0_,
         users0_.register_date as register13_62_0_,
         users0_.role_id as role18_62_0_,
         users0_.sex as sex62_0_,
         users0_.student_num as student15_62_0_,
         users0_.total_online_date as total16_62_0_,
         users0_.username as username62_0_
     from
         studentlifesupportplatform.user users0_
     where
         users0_.role_id=?
 WARN  net.sf.json.JSONObject
 Property 'transactionTimeout' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'URL' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'array' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'asciiStream' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'bigDecimal' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'binaryStream' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'blob' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'boolean' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'byte' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'bytes' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'characterStream' has no read method. SKIPPED
 WARN  net.sf.json.JSONObject
 Property 'clob' has no read method. SKIPPED
 ERROR  freemarker.runtime
 Method public java.lang.String org.apache.commons.lang.exception.NestableRuntimeException.getMessage(int) threw an exception when invoked on net.sf.json.JSONException: java.lang.reflect.InvocationTargetException
 Method public java.lang.String org.apache.commons.lang.exception.NestableRuntimeException.getMessage(int) threw an exception when invoked on net.sf.json.JSONException: java.lang.reflect.InvocationTargetException
 The problematic instruction:
 ----------
 ==> ${msg[0]} [on line 68, column 29 in org/apache/struts2/dispatcher/error.ftl]
 ----------

 Java backtrace for programmers:
 ----------
 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: java.lang.reflect.InvocationTargetException
     at freemarker.ext.beans.SimpleMethodModel.exec(SimpleMethodModel.java:130)
     at freemarker.ext.beans.SimpleMethodModel.get(SimpleMethodModel.java:138)
     at freemarker.core.DynamicKeyName.dealWithNumericalKey(DynamicKeyName.java:111)
     at freemarker.core.DynamicKeyName._getAsTemplateModel(DynamicKeyName.java:90)
     at freemarker.core.Expression.getAsTemplateModel(Expression.java:89)
     at freemarker.core.Expression.getStringValue(Expression.java:93)
     at freemarker.core.DollarVariable.accept(DollarVariable.java:76)
     at freemarker.core.Environment.visit(Environment.java:210)
     at freemarker.core.MixedContent.accept(MixedContent.java:92)
     at freemarker.core.Environment.visit(Environment.java:210)
     at freemarker.core.IfBlock.accept(IfBlock.java:82)
     at freemarker.core.Environment.visit(Environment.java:210)
     at freemarker.core.IteratorBlock$Context.runLoop(IteratorBlock.java:179)
     at freemarker.core.Environment.visit(Environment.java:417)
     at freemarker.core.IteratorBlock.accept(IteratorBlock.java:102)
     at freemarker.core.Environment.visit(Environment.java:210)
     at freemarker.core.MixedContent.accept(MixedContent.java:92)
     at freemarker.core.Environment.visit(Environment.java:210)
     at freemarker.core.IfBlock.accept(IfBlock.java:82)
     at freemarker.core.Environment.visit(Environment.java:210)
     at freemarker.core.MixedContent.accept(MixedContent.java:92)
     at freemarker.core.Environment.visit(Environment.java:210)
     at freemarker.core.Environment.process(Environment.java:190)
     at freemarker.template.Template.process(Template.java:237)
     at org.apache.struts2.dispatcher.Dispatcher.sendError(Dispatcher.java:797)
     at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:519)
     at org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
     at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91)
     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
     at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198)
     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
     at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
     at org.apache.catalina.core.StandardContextValve.__invoke(StandardContextValve.java:123)
     at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java)
     at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
     at org.apache.catalina.core.StandardHostValve.__invoke(StandardHostValve.java:171)
     at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java)
     at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
     at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936)
     at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
     at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
     at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004)
     at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
     at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
     at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
     at java.lang.Thread.run(Thread.java:662)
 Caused by: java.lang.NullPointerException
     at freemarker.ext.beans.SimpleMemberModel.unwrapArguments(SimpleMemberModel.java:85)
     at freemarker.ext.beans.SimpleMethodModel.exec(SimpleMethodModel.java:106)
     ... 49 more
 2014-6-3 1:07:12 org.apache.catalina.core.StandardWrapperValve invoke
 严重: Servlet.service() for servlet [default] in context with path [/StudentLifeSupportPlatformSystem] threw exception
 java.lang.IllegalStateException: Cannot call sendError() after the response has been committed
     at org.apache.catalina.connector.ResponseFacade.sendError(ResponseFacade.java:451)
     at org.apache.struts2.dispatcher.Dispatcher.sendError(Dispatcher.java:801)
     at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:519)
     at org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
     at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91)
     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
     at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198)
     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
     at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
     at org.apache.catalina.core.StandardContextValve.__invoke(StandardContextValve.java:123)
     at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java)
     at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
     at org.apache.catalina.core.StandardHostValve.__invoke(StandardHostValve.java:171)
     at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java)
     at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
     at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936)
     at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
     at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
     at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004)
     at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
     at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)
     at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
     at java.lang.Thread.run(Thread.java:662)

欢迎讨论交流, 我的主页:http://www.cnblogs.com/GDUT/

我的邮箱:zone.technology.exchange@gmail.com

JAVA对象转化JSON出现死循环问题的更多相关文章

  1. java对象与Json字符串之间的转化(fastjson)

    1. 首先引入jar包 在pom.xml文件里加入下面依赖: <dependency> <groupId>com.alibaba</groupId> <art ...

  2. java对象与Json字符串之间的转化

    public class Test { public static void main(String[] args) { // 实现java对象与Json字符串之间的转化 // 1. Person对象 ...

  3. jackson java对象和json对象的互相转换

    概述 Jackson框架是基于Java平台的一套数据处理工具,被称为“最好的Java Json解析器”. Jackson框架包含了3个核心库:streaming,databind,annotation ...

  4. json相关类库,java对象与json相互转换

    有效选择七个关于Java的JSON开源类库 转自:http://www.open-open.com/lib/view/open1397870197828.html 翻译: (英语原文:http://w ...

  5. java对象与json串互转

    1:java对象与json串转换: java对象—json串: JSONObject JSONStr = JSONObject.fromObject(object); String str = JSO ...

  6. java对象与json对象间的相互转换

    工程中所需的jar包,因为在网上不太好找,所以我将它放到我的网盘里了,如有需要随便下载. 点击下载 1.简单的解析json字符串 首先将json字符串转换为json对象,然后再解析json对象,过程如 ...

  7. ason 和 Java 对象转化示例

    1.工程 2.代码: JsonUtil.java package com.my.json; import java.util.ArrayList; import java.util.List; imp ...

  8. JSON-lib框架,JAVA对象与JSON、XML之间的相互转换

    Json-lib可以将Java对象转成json格式的字符串,也可以将Java对象转换成xml格式的文档,同样可以将json字符串转换成Java对象或是将xml字符串转换成Java对象. 一. 准备工作 ...

  9. java对象转json应clone,避免生成json串有问题

    今天因为一个java对象转json,搞了我一下午,在些记录一下: 是这样:我在strtuts2的action中调用services返回 Row: 26, 中国银行海鹰, 29, 东楼, 36, 1F ...

随机推荐

  1. openStack镜像制作

    参考链接: https://www.ibm.com/developerworks/community/wikis/home?lang=en#!/wiki/OpenStack/page/Creating ...

  2. Linux:远程到linux的图形界面

    一般linux都没有安装图形界面,可以通过VNC服务来实现步骤如下: 一.安装vnc server1.查看是否安装vncrpm -q vnc-serverpackage vnc is not inst ...

  3. 树莓派B+上手小记--使用HDMI线连接显示器

    入手还算比较顺利,一开始使用网上下的别人精简的OS,发现ACT及PWR灯一直亮着,上网查说用HDMI连接显示器需要修改配置文件config.txt,但修改后情况依旧. 如果还是用官方的系统试试吧,上网 ...

  4. ffmpeg去logo<转>

    用到 video filter —— delogo 通过周围像素插值去除 logo. 参数介绍: x y (必须)指定 logo 的坐标. w h (必须)指定 logo 的宽和高. band, t ...

  5. SHELL脚本攻略(学习笔记)--2.5 tr

    tr主要用于映射结果集.压缩和删除字符.我个人感觉特别有用,特别是压缩连续空格(空行)为一个空格(空行),让不规则的信息变得规则. 2.5.1 tr映射 tr [options] [SET1] [SE ...

  6. css3弹性盒子模型

    当下各种手机,平板尺寸不一,如果盒模型只能固定尺寸,不能随意压缩,将不能很好的迎合这个时代.所以css3推出了新的盒模型——弹性盒子模型(Flexible Box Model). 弹性盒模型可以水平布 ...

  7. 关于form标签,你该知道

    有没有发现,自己在写模板的时候很少使用form元素,一来form和table总是那么傻傻分不清楚:二来form的特性理解不清楚,有了input.label来了直接就上,根本不用form(不知道有没有人 ...

  8. 关于Oracle的性能调整(一)

    Oracle Tuning的一些总结 关于Oracle的性能调整,一般包括两个方面,一是指Oracle数据库本身的调整,比如SGA.PGA的优化设置,二是连接Oracle的应用程序以及SQL语句的优化 ...

  9. flume远程调试

    项目开发的时候,出现问题的时候,通常在IDE里面直接进行调试,但有时候我们可能用的是另外的一些开源框架,甚至运行程序里面没有一行代码是我们自己写的,如果出现一些较复杂的问题,那么我们可能就会用到远程调 ...

  10. Java核心知识点学习----线程同步工具类,CyclicBarrier学习

    线程同步工具类,CyclicBarrier日常开发较少涉及,这里只举一个例子,以做备注.N个人一块出去玩,相约去两个地方,CyclicBarrier的主要作用是等待所有人都汇合了,才往下一站出发. 1 ...