做客戶端開發要經常的和服務端進行互動,現在基本上都是使用
json
進行互動的,所以對於json
的生成和解析變得尤為重要,下面對自己日常工作中使用json
的進行一個記錄如下,以便一些剛學習的小夥伴參考和自己以後翻閱。
一、首先我們需要先新增fastjson
的依賴:
compile 'com.alibaba:fastjson:1.2.24'
複製程式碼
二、使用fastjson
來"製造"json
請求資料
我們在日常和伺服器互動的時候,經常是通過json
字串進行的,首先就先演示下如何造出下面的json
字串:
{
"cmd":"myApp/app/userCenter/queryFriend",
"userToken":"bfcb38b5bcbf463af031a1e7b9d284af",
"parameters":
{
"friend":"myGirlFriends"
}
}
複製程式碼
初步通過下面的程式碼實現:
//parametersMap用來生成parameters
Map<String, String> parametersMap = new HashMap<>();
parametersMap.put("friend", "myGirlFriends");
//upMap用來生成最終的上傳資料
Map<String, Object> upMap = new HashMap<>();
upMap.put("cmd", "myApp/app/userCenter/queryFriend");
upMap.put("userToken", "fc8b87f32bbdd8200de192350fd133cc");
upMap.put("parameters", parametersMap);
複製程式碼
這個時候的資料是這樣的:
{
cmd=myApp/app/userCenter/queryFriend,
userToken=fc8b87f32bbdd8200de192350fd133cc,
parameters={
friend=myGirlFriends
}
}
複製程式碼
上面只是生成了一組map
物件,我們和伺服器互動是通過json
字串進行的,請看下面程式碼:
//JSON包名為:import com.alibaba.fastjson.JSON;
String upParams = JSON.JSON.toJSONString(upMap);
複製程式碼
這個時候upParams
的結構就是我們想要的結構了
{
"cmd": "myApp/app/userCenter/queryFriend",
"userToken": "fc8b87f32bbdd8200de192350fd133cc",
"parameters": {
"friend": "myGirlFriends"
}
}
複製程式碼
upParams
可以用來傳送請求了。通過上面的例子,基本可以滿足和伺服器互動的請求格式,格式複雜點話,可能會有多層巢狀,只用使用Map來製造巢狀,最後使用fastjson
進行轉換就好了。
三、解析json
字串相關的操作
比如現在有一個json
字串需要我們解析,如下:
{
"name": "sean",
"id": "1",
"joined": [
{
"joinName": "joined1",
"joinId": "10"
},
{
"joinName": "joined2",
"joinId": "11"
},
{
"joinName": "joined3",
"joinId": "12"
}
]
}
複製程式碼
獲得這個json物件 只需要一行程式碼即可完成:
//string:json字串
//jsonObject:生成的json物件
JSONObject jsonObject = JSON.parseObject(string);
複製程式碼
1. 獲取json
物件中的一個元素的值:
string name = jsonObject.getString("name");
Log.d("name= "+name);
複製程式碼
得到的值為name= sean
2. 獲取json
物件中的一個陣列
一行程式碼:
//jsonObject:json物件
//joined:json物件中的一個欄位,裡面儲存的是一個json陣列。
JSONArray joinedArray = jsonObject .getJSONArray("joined");
此時,joinedArray 中的值為:
[
{
"joinName": "joined1",
"joinId": "10"
},
{
"joinName": "joined2",
"joinId": "11"
},
{
"joinName": "joined3",
"joinId": "12"
}
]
複製程式碼
遍歷該陣列:
for (int i = 0; i < joinedArray.size(); i++) {
JSONObject obj = joinedArray.getJSONObject(i);
Log.d("id= "+obj.getJoinId);
Log.d("name= "+obj.getJoinName);
}
複製程式碼
此時列印資料:
id= 10
name= joined1
id= 11
name= joined2
id= 12
name= joined3
複製程式碼
以上是個人總結,有什麼不對的地方歡迎指出、交流。
你可以通過以下方式關注我: