这里咱们来实现一个获取接口数据存入数据库的案例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));
}
}
此功能是把获取的数据存入数据库。
注意:其余层的数据以此类推便可实现。
的