您的位置:首页 > Web前端 > JavaScript

fastJson解析多层Json数据案例

2017-11-26 14:37 465 查看
这里我们来实现一个获取接口数据存入数据库的案例

例如数据:

{   "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

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

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

[java] view
plain copy

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

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

[java] view
plain copy

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

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

[java] view
plain copy

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));
}
}

此功能是把获取的数据存入数据库。
注意:其他层的数据以此类推即可实现。

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