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