加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

net.sf.json.JSONException: java.lang.reflect.InvocationTarge

发布时间:2020-12-16 18:56:52 所属栏目:百科 来源:网络整理
导读:博客分类: json .net Java json Hibernate json-lib对象转化为json数据抛net.sf.json.JSONException: va.lang.reflect.InvocationTargetException异常 出现了两种情况: 日期格式 hibernate延时加载 解决:日期格式 private java.util.Date createTime; 只在


    博客分类:
  • json
.net Java json Hibernate

json-lib对象转化为json数据抛net.sf.json.JSONException: va.lang.reflect.InvocationTargetException异常

出现了两种情况:

  1. 日期格式
  2. hibernate延时加载

解决:日期格式

private java.util.Date createTime;

只在字段前声明Date的数据类型可能也会抛异常,在Set,get方法中,有出现Date类型的都把包名加上

解决:hibernate延时加载 设置

Java代码
  1. JsonConfigcfg=newJsonConfig();
  2. cfg.setExcludes(newString[]{"handler","hibernateLazyInitializer"});

方法举例

Java代码
  1. /**
  2. *datagrideasyui查找出联系人pager-公共的,和自已创建的可以查看
  3. */
  4. @Transactional(readOnly=true)
  5. publicJSONArraydatagrid(Pager<AddressBook>page,Useruser,DetachedCriteriadetachedCriteria){
  6. //有级联,不能直接转化,要取出List放到map里面
  7. JsonConfigcfg=newJsonConfig();
  8. //过滤关联,避免死循环net.sf.json.JSONException:java.lang.reflect.InvocationTargetException
  9. cfg.setJsonPropertyFilter(newPropertyFilter()
  10. {
  11. publicbooleanapply(Objectsource,Stringname,Objectvalue){
  12. if(name.equals("addressGroup")||name.equals("user")||name.equals("createTime")||name.equals("birthday")){
  13. returntrue;
  14. }else{
  15. returnfalse;
  16. }
  17. }
  18. });
  19. //net.sf.json.JSONException:java.lang.reflect.InvocationTargetException异常
  20. cfg.setExcludes(newString[]{"handler","hibernateLazyInitializer"});
  21. //javabean里出现循环调用啦,赶快用excludes干掉parent或者children
  22. //cfg.setExcludes(newString[]{"addressGroup"});
  23. //net.sf.json.JSONException:java.lang.reflect.InvocationTargetException日期格式转化出错
  24. //cfg.setCycleDetectionStrategy(CycleDetectionStrategy.LENIENT);
  25. //cfg.registerJsonValueProcessor(Date.class,newDateJsonValueProcessor("yyyy-MM-ddhh:mm:ss"));
  26. Pager<AddressBook>pager=this.findAllByApprove(page,user,detachedCriteria);
  27. longtotal=pager.getTotalCount();
  28. List<AddressBook>list=pager.getResult();
  29. Map<String,Object>result=newHashMap<String,Object>();
  30. result.put("total",total);
  31. result.put("rows",list);
  32. JSONArrayjsonArray=JSONArray.fromObject(result,cfg);
  33. returnjsonArray;
  34. }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读