今天非常高兴,解决了一个关于java类转json时有关联对象而且困扰我很久的BUG
来源:互联网 发布:淘宝云客服在哪里 编辑:程序博客网 时间:2024/04/30 03:22
之前在做毕设的时候,在java类转json且有关联对象的时候总是会遇到如下的错误,真的是困扰我很久
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:221) at freemarker.core.MixedContent.accept(MixedContent.java:92) at freemarker.core.Environment.visit(Environment.java:221) at freemarker.core.IfBlock.accept(IfBlock.java:82) at freemarker.core.Environment.visit(Environment.java:221) at freemarker.core.IteratorBlock$Context.runLoop(IteratorBlock.java:179) at freemarker.core.Environment.visit(Environment.java:428) at freemarker.core.IteratorBlock.accept(IteratorBlock.java:102) at freemarker.core.Environment.visit(Environment.java:221) at freemarker.core.MixedContent.accept(MixedContent.java:92) at freemarker.core.Environment.visit(Environment.java:221) at freemarker.core.IfBlock.accept(IfBlock.java:82) at freemarker.core.Environment.visit(Environment.java:221) at freemarker.core.MixedContent.accept(MixedContent.java:92) at freemarker.core.Environment.visit(Environment.java:221) at freemarker.core.Environment.process(Environment.java:199) at freemarker.template.Template.process(Template.java:259) at org.apache.struts2.dispatcher.Dispatcher.sendError(Dispatcher.java:845) at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:567) 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:233) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) 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.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1008) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589) at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at java.lang.Thread.run(Unknown Source)Caused by: java.lang.NullPointerException at freemarker.ext.beans.SimpleMemberModel.unwrapArguments(SimpleMemberModel.java:86) at freemarker.ext.beans.SimpleMethodModel.exec(SimpleMethodModel.java:106) ... 51 more
之前每次都是明奇妙的解决掉了,连自己也不清楚到底什么原因,网上有说因为延迟加载问题,我也试了但是没解决,终于在昨天再次遇到了不过这次我却怎么也绕不过去,尝试千方百计,主要有以下几种
- 延迟加载设为lazy,
- 排除管对象
- 类要是public
不过这几种方法都没能解决我的问题,今天终于发现问题最终出现在哪儿了,之前有过要获取某个关联对象中的某个属性,但是是关联对象又不能加入转换json因为会陷入死循环,所以我就加了一些get方法用于获取这些属性,问题就在这里!!!看下面这段代码,被涂色的就是我写的两个get方法用于获得某个关联对象的某个属性的,黄色是修改之前的写法,这种写法在关联对象确实存在的时候是不会出错的,但是一旦不存在就蒙蔽了,所以加了个判断如红色部分。
public class Teacher implements java.io.Serializable {// Fieldsprivate String tid;private Specialty specialty;//专业private Academy academy;//学院private String password;private String tname;private String tsex;//性别private Integer age;//年龄private String educationrecoder;//学历private String positiontitle;//职称private String tposition;//职位private String telephone;private Set<Graduationsubject> graduationsubjects = new HashSet<Graduationsubject>(0);//毕设题目private Set<MyRole> myRoles = new HashSet<MyRole>(0);private Set<Student> students = new HashSet<Student>(0);//指导学生private Set<Replygroup> replygroups = new HashSet<Replygroup>(0);//答辩小组public String getSpecialtyname(){return this.specialty.getSpname();}public String getAcademyname(){if(this.academy != null)return this.academy.getAcname();elsereturn "";}
0 0
- 今天非常高兴,解决了一个关于java类转json时有关联对象而且困扰我很久的BUG
- 今天解决了一直困扰我很久的两个问题
- 解决了一个困惑很久的bug
- 预编译,编译,汇编,链接,这些困扰我很久的东西今天是个了结了
- 今天解决了困扰我几天的一个问题(F5与Shift+F5)
- 分享困扰了我很久的问题关于boot.ini的修改
- 当一个bug困扰你很久都解决不了的时候,它很可能就是一个低级错误
- 困扰很久的opencv打不开视频问题终于解决了
- 困扰了我一天的BUG,哎!
- 困扰我快一个月的BUG
- 今天解决了困扰我好久的问题。。。好高兴啊
- 今天长期困扰我的一个问题 终于解决 不多说看文章
- 困扰了我两天的一个exception
- 一个困扰我许久的问题解决了
- 困扰很久的问题。今天下午搞定了。
- 汇总一些困扰了很久的问题
- 一个感动了我很久的故事
- 困扰了我很久STM32的TIM1时钟走慢的问题终于找到原因了
- 华为2017 校园招聘
- D. The Union of k-Segments----扫描线初步
- 文章收藏
- 挖地雷
- BOM 页面尺寸位置等知识点
- 今天非常高兴,解决了一个关于java类转json时有关联对象而且困扰我很久的BUG
- 【算法与数据结构】二维数组中寻找鞍点
- Python爬虫入门四之Urllib库的高级用法
- Oracle JSON 字符串处理实例
- 1002. 写出这个数 (20)
- [POJ3415]公共子串
- css经常需要hack
- java 包的概念
- POJ2352 Stars 树状数组