Bootstrap

fastJson解析多层Json数据案例

这里我们来实现一个获取接口数据存入数据库的案例

例如数据:

{   "code":200,   "msg":"ok",   "data":{

        "collectionlist":[
                  {
                 "visit_person_id":"xxxxx",     //走访姓名
                 "equipment_id":"xxxxx",        //设备ID
                 "name": "吴xx",                //走访人员姓名
                 "visit_records": [
                                {
                                 "visit_id": "216", //走访记录标识
                                  "visit_person_id": "31", //走访人员标识
                                  "business_id": "670", //企业ID
                                "business_name":{
                                           //返回的企业姓名等所有相关信息
                                           //参考接口2.返回字段
                                              },
                                "question_subject": {
                                     返回的问题的所有相关信息
                                     //参考接口3.返回字段       
                                               },
                           } ]
                             },
.....
                        ]
                  }
 }

一,首先理解JSONArrary和JsonObject

1、JSONObject和JSONArray的数据表示形式

JSONObject的数据是用 {  } 来表示的,

        例如:   { "id" : "123", "courseID" : "huangt-test", "title" : "提交作业", "content" : null  }  

而JSONArray,顾名思义是由JSONObject构成的数组,用  [ { } , { } , ......  , { } ]  来表示

       例如:   [ {  "id" : "123", "courseID" : "huangt-test", "title" : "提交作业" }  ,  {  "content" : null, "beginTime" : 1398873600000  "endTime" } ] ; 

        表示了包含2个JSONObject的JSONArray。

可以看到一个很明显的区别,一个最外面用的是 {  }  ,一个最外面用的是 [  ]  ;

2、如何从字符串String获得JSONObject对象和JSONArray对象

          JSONObject  jsonObject  = new JSONObject ( String  str);

         JSONArray jsonArray = new JSONArray(String    str  ) ;

3、如何从JSONArray中获得JSONObject对象

       大家可以把JSONArray当成一般的数组来对待,只是获取的数据内数据的方法不一样

                   JSONObject   jsonObject  =  jsonArray.getJSONObject(i) ;    

4、获取JSON内的数据

      int   mid= jsonObject.getInt ( "id" ) ;    //  这里的mid得到的数据就是123.

      String  mcourse=jsonObject.getString( " courseID") ;   // 这里的mcourse得到的数据就是huangt-test.

参考地址:http://blog.csdn.net/u014260748/article/details/41521123

二,fastJson中JsonArray和JsonObject之间的转换以及结合list转换

第一步:先获取jsonobject对象

[java] view plain copy

  1. JSONObject obj=JSONObject.parseObject(result);//获取jsonobject对象  


第二步:把对象转换成jsonArray数组

[java] view plain copy

  1. arr=obj.getJSONArray("resultData");//获取的结果集合转换成数组  


第三步:将数组转换成字符串:

[java] view plain copy

  1. String js=JSONObject.toJSONString(arr, SerializerFeature.WriteClassName);//将array数组转换成字符串  


第四步:将字符串转成list集合

[java] view plain copy

  1. List<JmtCase>  collection = JSONObject.parseArray(js, JmtCase.class);//把字符串转换成集合  

参看文献:http://blog.csdn.net/qq_35357001/article/details/68946066

都这里基本fastJson解析数据可以实现。

三,案例实现如获取二层数据集visit_records

......

......此处是获取接口或者其他地方的数据下面去解析

......

//fastJson解析中文字节编码
//获取jsonobject对象
JSONObject jsonObject = (JSONObject) JSONObject.parseObject(sb.toString()).getJSONObject("data");
//获取jsonArray数组数据
JSONArray jsonArray = (JSONArray)jsonObject.getJSONArray("collectionlist");
         for (Iterator iterator = jsonArray.iterator(); iterator.hasNext();) {
             JSONObject jsonObject1 = (JSONObject) iterator.next();
             JSONArray jsonArray1 = (JSONArray)jsonObject1.getJSONArray("visit_records");
             //将数组转换成字符串
             String strArr = JSONObject.toJSONString(jsonArray1);//将array数组转换成字符串
             //将字符串转成list集合
             List<IVisitRecords> collectionLists = JSONObject.parseArray(strArr, IVisitRecords.class);//把字符串转换成集合
             for (int i = 0; i < collectionLists.size(); i++) {
                 iVisitRecordsService.insert(collectionLists.get(i));
             }
         }

此功能是把获取的数据存入数据库。

注意:其他层的数据以此类推即可实现。

;