JAVA对象转化JSON出现死循环问题
主要是解决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出现死循环问题的更多相关文章
- java对象与Json字符串之间的转化(fastjson)
1. 首先引入jar包 在pom.xml文件里加入下面依赖: <dependency> <groupId>com.alibaba</groupId> <art ...
- java对象与Json字符串之间的转化
public class Test { public static void main(String[] args) { // 实现java对象与Json字符串之间的转化 // 1. Person对象 ...
- jackson java对象和json对象的互相转换
概述 Jackson框架是基于Java平台的一套数据处理工具,被称为“最好的Java Json解析器”. Jackson框架包含了3个核心库:streaming,databind,annotation ...
- json相关类库,java对象与json相互转换
有效选择七个关于Java的JSON开源类库 转自:http://www.open-open.com/lib/view/open1397870197828.html 翻译: (英语原文:http://w ...
- java对象与json串互转
1:java对象与json串转换: java对象—json串: JSONObject JSONStr = JSONObject.fromObject(object); String str = JSO ...
- java对象与json对象间的相互转换
工程中所需的jar包,因为在网上不太好找,所以我将它放到我的网盘里了,如有需要随便下载. 点击下载 1.简单的解析json字符串 首先将json字符串转换为json对象,然后再解析json对象,过程如 ...
- ason 和 Java 对象转化示例
1.工程 2.代码: JsonUtil.java package com.my.json; import java.util.ArrayList; import java.util.List; imp ...
- JSON-lib框架,JAVA对象与JSON、XML之间的相互转换
Json-lib可以将Java对象转成json格式的字符串,也可以将Java对象转换成xml格式的文档,同样可以将json字符串转换成Java对象或是将xml字符串转换成Java对象. 一. 准备工作 ...
- java对象转json应clone,避免生成json串有问题
今天因为一个java对象转json,搞了我一下午,在些记录一下: 是这样:我在strtuts2的action中调用services返回 Row: 26, 中国银行海鹰, 29, 东楼, 36, 1F ...
随机推荐
- iScroll滚动区域中select、input、textarea元素无法点击的Bug修复
最近在一个项目中使用了iScroll4模拟滚动效果,调试过程中发现一个表单页中的所有表单项都无法点击聚焦, 如<select>.<input>.<textarea> ...
- uva 10340 All in All
水题,从头到尾扫一遍就可以了,输入两个字符串s和t,判断是否可以从t中删除0个或多个字符(其他字符顺序不变),得到字符串s.例如,abcde可以得到bce,但无法得到dc. #include<a ...
- 百度地图API示例之设置级别setZoom与禁止拖拽disableDragging
百度地图API示例之设置级别setZoom与禁止拖拽disableDragging 设置级别 <html> <head> <meta http-equiv="C ...
- 百度地图API示例之添加定位相关控件
代码 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" cont ...
- jsp配置项目时出错Deployment failure on Tomcat 6.x. Could not copy all resources to
转自:http://www.2cto.com/kf/201201/116853.html 今天在网上部署项目的时候出现在了问题 tomcat一直部署不上 网上查了一下 原因记下来供大家查看 Deplo ...
- PIC32MZ tutorial -- 32-bit Timer
The microcontroller is PIC32MZ2048ECH144 on the PIC32MZ EC Starter Kit. This microcontroller has fou ...
- 单机运行环境搭建之 --CentOS-6.5安装配置Tengine
一.安装pcre: cd /usr/local/src wget http://downloads.sourceforge.net/project/pcre/pcre/8.34/pcre-8.34 ...
- 多个 git ssh key 配置 Ubuntu os
1.生成ssh key: ssh-keygen -t rsa -C “email@sss.com” 此时,在~/.ssh/文件夹下会有两个文件, id_rsa 和 id_rsa.pub.分别保存ssh ...
- android 编译错误 com/android/dx/command/dexer/Main : Unsupported major.minor version 52.0
解决方案一: JDK版本不一致造成的,指的是高版本的JDK编译的class不能放在低版本的JDK上运行. 如果是Version 52,就表示JDK8编译的class不能运行在JDK7上,所以需要在本地 ...
- clang format 自定义样式常用参数说明
常用的格式设置: #如果为真(true),分析格式化过的文件中最常见的&和*的对齐方式.然后指针对齐仅作为回退 DerivePointerAlignment: false #缩进宽度 Inde ...