开发者社区> 落葉知秋> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

解决json转换问题:net.sf.ezmorph.bean.MorphDynaBean cannotbe cast to xxx

简介: 解决json转换问题:net.sf.ezmorph.bean.MorphDynaBean cannotbe cast to xxx
+关注继续查看

在操作json的数据格式的时候,如果没有指明数据类型,那么只能是基本类型或者是String类型,不能出现复杂数据类型。

for(Map<String, Object> map : datas){
            String gw_id = map.get("GW_ID").toString();
            gw_id =  gw_id.substring(0, 14)+"1"+gw_id.substring(15);
            map.put("GW_ID", gw_id);
            map.put("UPDATE_TIME", new Date().getTime());
            map.put("CREATE_TIME", map.get("CREATE_TIME"));
            map.put("LAST_COLLECT_TIME", map.get("LAST_COLLECT_TIME"));
            Set<String> keys =  map.keySet();
            for(String key:keys){
                if(null == map.get(key)){
                    map.put(key, "");
                }
            }
        }
String jsondata = JSONArray.fromObject(datas).toString();
JSONArray jsonarray = JSONArray.fromObject(jsondata );
 List<Map<String, Object>> objs = (List<Map<String, Object>>)JSONArray.toCollection(jsonarray, Map.class);

在这里,因为得到json字符串的时候用的是 JSONArray.fromObject(collenction),所有,在讲json字符串转换成json对象的时候,也只能用JSONArray.toCollection,并且,一定要带上后面的class参数。

将json字符串转换成对应的json对象以后,在遍历json对象时

for(Map<String, Object> data : objs)
data.get("LAST_COLLECT_NUM")

此时,get()方法得到的是对象,并且是只能转换成基本数据类型或者是String类型的,如果强制转化成复杂的类型,会提示这个错误。

再如:

Teacher类中,有三个属性。

private String teaId;  
private String teaName;  
private List<Student> stus;  
Teacher teacher_1 = new Teacher("编号1", "教师1", stus);  
JSONObject obj = JSONObject.fromObject(teacher_1);

这一步,将Teacher 对象转换成json字符串的时候,没有任何的问题。

下面,将JSONObject 转换成Teacher 对象,如果,不加后面的class参数,也会报这儿错误。加了后,这一步也正常。

Teacher teacherBean = (Teacher) JSONObject.toBean(obj, Teacher.class);Student studentBean = teacherBean.getStus().get(0);

当从teacherBean 对象中取出stus属性的值时候,就会提示:

java.lang.ClassCastException:net.sf.ezmorph.bean.MorphDynaBean cannot be cast to com.edu.xukai.Student

用这种方式可以解决:

map.put("stus", Student.class); 
 Teacher teacherBean = (Teacher) JSONObject.toBean(obj, Teacher.class, map);

其中map对象是teacherBean对象中各个属性的类型,map额key是属性每次,value是属性的类型。

JSONArray.toArray(jsonArray, objectClass, classMap)
JSONArray.toList(jsonArray, objectClass, classMap)

也支持这样的方式。

顺便贴一下我自己写的一个公共方法,后续再继续优化

     /**
     * 封装返回参数
     * @param requestBody
     * @param beanClass
     * @param <T>
     * @return
     * @throws IllegalAccessException
     * @throws InstantiationException
     */
    public <T> T result(String requestBody, Class<T> beanClass, Map<String,Object> map) throws IllegalAccessException, InstantiationException {
        T t = beanClass.newInstance();
        JSONObject jsonObject = null;
        JSONArray jsonarr= null;
        if(null != requestBody){
            jsonObject = JSONObject.fromObject(requestBody);
            if(jsonObject.has("status")){
                if(jsonObject.getString("status").equalsIgnoreCase("0")){
                    jsonarr= jsonObject.getJSONArray("data");
                    if(jsonarr.size() > 0){
                        //json对象转换成java对象
                        if(null == map){
                            t = (T) JSONObject.toBean(jsonarr.getJSONObject(0),beanClass);
                        }else{
                            t = (T) JSONObject.toBean(jsonarr.getJSONObject(0),beanClass,map);
                        }
                    }
                }else{
                    System.out.println("==================================================================获取返回失败信息=========》》》》》》"+jsonObject.getString("msg"));
                    return t;
                }
            }else{
                System.out.println("==================================================================获取返回失败信息=========》》》》》》"+requestBody);
                return null;

                //jsonObject= JSONObject.fromObject(requestBody);
                //json对象转换成java对象
                //t = (T) JSONObject.toBean(jsonObject,beanClass);

                //jsonarr= JSONArray.fromObject(requestBody);
                //json对象转换成java对象
                //t = (T) JSONObject.toBean(jsonarr.getJSONObject(0),beanClass);
            }
        }
        return t;
    }

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Mac OS X下架设WebDAV Git Server
因为我的 mac mini server 不想开著 ssh 一直给人扫,所以想设定 https 的 git server,试了一下真的超简单的。
94 0
在Mac OS X 10.8中配置Apache + PHP + MySQL
在Mac OS X 10.8中配置Apache+PHP+MySQL的内容包括: 配置Apache 配置PHP 安装MySQL 配置PHPAdmin 设置数据库默认字符集 一. 配置Apache 1.
789 0
Mac OS X 10.10 运行 Eclipse 提示需要安装 Java
于 OS X 的 Java 2014-001 Download “适用于 OS X 的 Java 2014-001”改进了安装过程,并会取代之前所有版本的“适用于 OS X 的 Java”。
948 0
ORA-26040: Data block was loaded using the NOLOGGING option
测试如下: SQL> create table testerr  2  as  3  select * from dba_objects where 1=2; Table created SQL> alter table testerr nologging; Table altered 然后进行备份,然后。
901 0
ORA-1652: unable to extend temp segment by 128 in tablespace xxx Troubleshootin
当收到告警信息ORA-01652: unable to extend temp segment by 128 in tablespace xxxx 时,如何Troubleshooting ORA-1652这样的问题呢? 当然一般xxx是临时表空间,也有可能是用户表空间。
1711 0
+关注
17
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载