最近在工作时发现使用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;
}