頂級的JSON對象可能包含下面這些屬性
屬性值類型: 字符串(string)
父節(jié)點(diǎn): -
呈現(xiàn)請求中服務(wù)API期望的版本,以及在響應(yīng)中保存的服務(wù)API版本。應(yīng)隨時(shí)提供apiVersion。這與數(shù)據(jù)的版本無關(guān)。將數(shù)據(jù)版本化應(yīng)該通過其他的機(jī)制來處理,如etag。
示例:
{ "apiVersion": "2.1" }
屬性值類型: 字符串(string)
父節(jié)點(diǎn): -
客戶端設(shè)置這個(gè)值,服務(wù)器通過數(shù)據(jù)作出回應(yīng)。這在JSON-P和批處理中很有用,用戶可以使用_context_將響應(yīng)與請求關(guān)聯(lián)起來。該屬性是頂級屬性,因?yàn)椴还茼憫?yīng)是成功還是有錯(cuò)誤,_context_總應(yīng)當(dāng)被呈現(xiàn)出來。_context_不同于_id_在于_context_由用戶提供而_id_由服務(wù)分配。
示例:
請求 #1:
http://www.google.com/myapi?context=bart
請求 #2:
http://www.google.com/myapi?context=lisa
響應(yīng) #1:
{
"context": "bart",
"data": {
"items": []
}
}
響應(yīng) #2:
{
"context": "lisa",
"data": {
"items": []
}
}
公共的JavaScript處理器通過編碼同時(shí)處理以下兩個(gè)響應(yīng):
function handleResponse(response) {
if (response.result.context == "bart") {
// 更新頁面中的 "Bart" 部分。
} else if (response.result.context == "lisa") {
// 更新頁面中的 "Lisa" 部分。
}
}
屬性值類型: 字符串(string)
父節(jié)點(diǎn): -
服務(wù)提供用于識別響應(yīng)的標(biāo)識(無論請求是成功還是有錯(cuò)誤)。這對于將服務(wù)日志和單獨(dú)收到的響應(yīng)對應(yīng)起來很有用。
示例:
{ "id": "1" }
屬性值類型: 字符串(string)
父節(jié)點(diǎn): -
表示對數(shù)據(jù)即將執(zhí)行,或已被執(zhí)行的操作。在JSON請求的情況下,_method_屬性可以用來指明對數(shù)據(jù)進(jìn)行何種操作。在JSON響應(yīng)的情況下,_method_屬性表明對數(shù)據(jù)進(jìn)行了何種操作。
一個(gè)JSON-RPC請求的例子,其中_method_屬性表示要在_params_上執(zhí)行的操作:
{
"method": "people.get",
"params": {
"userId": "@me",
"groupId": "@self"
}
}
屬性值類型: 對象(object)
父節(jié)點(diǎn): -
這個(gè)對象作為輸入?yún)?shù)的映射發(fā)送給RPC請求。它可以和_method_屬性一起用來執(zhí)行RPC功能。若RPC方法不需要參數(shù),則可以省略該屬性。
示例:
{
"method": "people.get",
"params": {
"userId": "@me",
"groupId": "@self"
}
}
屬性值類型: 對象(object)
父節(jié)點(diǎn): -
包含響應(yīng)的所有數(shù)據(jù)。該屬性本身擁有許多保留屬性名,下面會有相應(yīng)的說明。服務(wù)可以自由地將自己的數(shù)據(jù)添加到這個(gè)對象。一個(gè)JSON響應(yīng)要么應(yīng)當(dāng)包含一個(gè)_data_對象,要么應(yīng)當(dāng)包含_error_對象,但不能兩者都包含。如果_data_和_error_同時(shí)出現(xiàn),則_error_對象優(yōu)先。
屬性值類型: 對象(object)
父節(jié)點(diǎn): -
表明錯(cuò)誤發(fā)生,提供錯(cuò)誤的詳細(xì)信息。錯(cuò)誤的格式支持從服務(wù)返回一個(gè)或多個(gè)錯(cuò)誤。一個(gè)JSON響應(yīng)可以有一個(gè)_data_對象或者一個(gè)_error_對象,但不能兩者都包含。如果_data_和_error_都出現(xiàn),_error_對象優(yōu)先。
示例:
{
"apiVersion": "2.0",
"error": {
"code": 404,
"message": "File Not Found",
"errors": [{
"domain": "Calendar",
"reason": "ResourceNotFoundException",
"message": "File Not Found
}]
}
}
更多建議: