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

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

发布时间:2020-12-16 19:53:53 所属栏目:百科 来源:网络整理
导读:json-lib对象转化为json数据抛net.sf.json.JSONException: va.lang.reflect.InvocationTargetException异常 出现了两种情况: 日期格式 hibernate延时加载 解决:日期格式 private java.util.Date createTime; 只在字段前声明Date的数据类型可能也会抛异常,

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"});

方法举例

/**
  • *datagrideasyui查找出联系人pager-公共的,和自已创建的可以查看
  • */
  • @Transactional(readOnly=true)
  • publicJSONArraydatagrid(Pager<AddressBook>page,Useruser,DetachedCriteriadetachedCriteria){
  • //有级联,不能直接转化,要取出List放到map里面
  • //过滤关联,避免死循环net.sf.json.JSONException:java.lang.reflect.InvocationTargetException
  • cfg.setJsonPropertyFilter(newPropertyFilter()
  • {
  • publicbooleanapply(Objectsource,Stringname,Objectvalue){
  • if(name.equals("addressGroup")||name.equals("user")||name.equals("createTime")||name.equals("birthday")){
  • returntrue;
  • }else{
  • false;
  • }
  • });
  • //net.sf.json.JSONException:java.lang.reflect.InvocationTargetException异常
  • "hibernateLazyInitializer"});
  • //javabean里出现循环调用啦,赶快用excludes干掉parent或者children
  • //cfg.setExcludes(newString[]{"addressGroup"});
  • //net.sf.json.JSONException:java.lang.reflect.InvocationTargetException日期格式转化出错
  • //cfg.setCycleDetectionStrategy(CycleDetectionStrategy.LENIENT);
  • //cfg.registerJsonValueProcessor(Date.class,newDateJsonValueProcessor("yyyy-MM-ddhh:mm:ss"));
  • Pager<AddressBook>pager=this.findAllByApprove(page,user,detachedCriteria);
  • longtotal=pager.getTotalCount();
  • List<AddressBook>list=pager.getResult();
  • Map<String,Object>result=newHashMap<String,Object>();
  • result.put("total",total);
  • result.put("rows",list);
  • JSONArrayjsonArray=JSONArray.fromObject(result,cfg);
  • returnjsonArray;
  • }
  • (编辑:李大同)

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

      推荐文章
        热点阅读