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

最近在工作时发现使用json做数据转换会有一些坑。而我主要是遇到第二个情况。就是如果从数据库读出来有DateTime类型的数据使用系统自带的工具类序列化后将得到一个很长的数字表示,或者再做其他操作就会因为这个格式报错。
找到一位前辈的记录这里转一下:https://blog.csdn.net/ye1992/article/details/17436765

执行:
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延时加载 设置

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

方法举例

/** 
 * 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;  
      
      
}  

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,778评论 18 399
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,184评论 6 13
  • 要打败自己,就要用心的对自己剖析。懂得了自己,才能把自己的伪装撕下,不断压迫自己,让自己前进。一切都愿意只有压力才...
    jerish阅读 617评论 0 0
  • 爱你的人太多 你爱的是哪一个 能去的地方太多 你想去的是哪一个 拥有的东西太多 你珍惜过哪一个 途,是风景也是柴米...
    塞纳河水流阅读 202评论 0 0
  • 现在以山寨币PPY为例子来演示如何在内盘购买PPY 1. 注册 点击打开openledger.io,看到下图 点击...
    古萧龙城IT青年阅读 1,878评论 0 2