fastjson解析多层数据_fastJson解析多层Json数据案例

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

例如数据:java

{   "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.返回字段

},

} ]

},

.....

]

}

}json

一,首先理解JSONArrary和JsonObject

一、JSONObject和JSONArray的数据表示形式数组

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

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

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

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

表示了包含2个JSONObject的JSONArray。code

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

二、如何从字符串String得到JSONObject对象和JSONArray对象

JSONObject  jsonObject  = new JSONObject ( String  str);

JSONArray jsonArray = new JSONArray(String    str  );

三、如何从JSONArray中得到JSONObject对象

你们能够把JSONArray当成通常的数组来对待,只是获取的数据内数据的方法不同

JSONObject   jsonObject  =  jsonArray.getJSONObject(i) ;

四、获取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对象

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

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

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

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

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

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

List  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 collectionLists = JSONObject.parseArray(strArr, IVisitRecords.class);//把字符串转换成集合

for (int i = 0; i < collectionLists.size(); i++) {

iVisitRecordsService.insert(collectionLists.get(i));

}

}

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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值