您的位置:首页 > 编程语言 > Java开发

json数据转换异常:net.sf.json.JSONException: java.lang.reflect.InvocationTargetException

2017-04-02 10:35 585 查看
执行:

JSONArray array = JSONArray.fromObject(this.users);

就会报以下错误:

net.sf.json.JSONException: Java.lang.reflect.InvocationTargetException

users是一个list集合

方案一:

JSONArray array = JSONArray.fromObject(this.users.toArray()); 

方案二:

因为bean里有Date字段,且从数据库里读出来的是java.sql.Date赋值给了java.util.Date,转化成JSONArray时出错;可以在从数据库读出Date 时直接写成:new java.util.Date(rs.getDate("date").getTime),这样就不会出错了;

方案三:

日期格式
hibernate延时加载

1.解决:日期格式

 

private java.util.Date createTime; 

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

 

2.解决:hibernate延时加载 设置

Java代码  


JsonConfig cfg = new JsonConfig();  

  

cfg.setExcludes(new String[]{"handler","hibernateLazyInitializer"});  

 

方法举例

Java代码  


               /** 

 * datagrid easyui 查找出联系人pager-公共的,和自已创建的可以查看 

 */  

@Transactional(readOnly = true)  

public JSONArray datagrid(Pager<AddressBook> page,User user,DetachedCriteria detachedCriteria){  

    //有级联,不能直接转化,要取出List放到map里面  

    JsonConfig cfg = new JsonConfig();  

    //过滤关联,避免死循环net.sf.json.JSONException: java.lang.reflect.InvocationTargetException  

    cfg.setJsonPropertyFilter(new PropertyFilter()  

    {  

         public boolean apply(Object source, String name, Object value) {  

           if(name.equals("addressGroup")||name.equals("user")||name.equals("createTime")||name.equals("birthday")) {  

             return true;  

           } else {  

             return false;  

          }  

        }  

       });  

    //net.sf.json.JSONException: java.lang.reflect.InvocationTargetException异常  

   cfg.setExcludes(new String[]{"handler","hibernateLazyInitializer"});  

    //javabean里出现循环调用啦,赶快用excludes干掉parent或者children   

   // cfg.setExcludes(new String[]{"addressGroup"});   

    //net.sf.json.JSONException: java.lang.reflect.InvocationTargetException日期格式转化出错  

   // cfg.setCycleDetectionStrategy(CycleDetectionStrategy.LENIENT);     

    //cfg.registerJsonValueProcessor(Date.class, new DateJsonValueProcessor("yyyy-MM-dd hh:mm:ss"));  

      

    Pager<AddressBook> pager=this.findAllByApprove(page, user, detachedCriteria);  

    long total=pager.getTotalCount();  

    List<AddressBook> list=pager.getResult();  

    Map<String,Object> result=new HashMap<String,Object>();  

    result.put("total", total);  

    result.put("rows", list);  

    JSONArray jsonArray  = JSONArray.fromObject(result,cfg);     

    return jsonArray;  

      

      

}  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐