您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)WebApiClient的JsonPatch局部更新是怎樣的,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
隨著WebApiClient的不斷完善,越來越多開發(fā)者選擇WebApiClient替換原生的HttpClient,下面將介紹使用WebApiClient來完成JsonPatch提交的新特性。
在服務(wù)端WebApi開發(fā)的時候,如果設(shè)計(jì)一個更新登錄用戶的個人信息的接口,用戶能更新昵稱、密碼、生日、性別等N多個字段,但用戶在實(shí)際使用中,可能是更新其中的一個或不確定多個字段。開發(fā)者往往會為難:對于客戶端沒有更新到的字段,應(yīng)該設(shè)置為什么值呢?一種是讓客戶端從服務(wù)器同步后再更新相關(guān)字段,一種是不更新的字段設(shè)置為null,服務(wù)器收到null的字段不更新,但這個還是有歧義(要更新為null的情況)。
json patch是為客戶端能夠局部更新服務(wù)端已存在的資源而設(shè)計(jì)的一種標(biāo)準(zhǔn)交互,在RFC6902里有詳細(xì)的介紹json patch,通俗來講有以下幾個要點(diǎn):
使用HTTP PATCH請求方法;
請求body為描述多個opration的數(shù)據(jù)json內(nèi)容;
請求的Content-Type為application/json-patch+json;
以下為一個json patch請求的數(shù)據(jù)包:
op為操作的意思,分為以下幾種:
add 添加:{“op”: "add", "path": "/xxx", "value": "xxx"},如果該屬性不存,那么就添加該屬性,如果屬性存在,就改變屬性的值。
remove 刪除:{“op”: "remove", "path": "/xxx"},刪除某個屬性,或把它設(shè)為默認(rèn)值(例如空值)。
replace 替換:{“op”: "replace", "path": "/xxx", "value": "xxx"},改變屬性的值,也可以理解為先執(zhí)行了刪除,然后進(jìn)行添加。
copy 復(fù)制:{“op”: "copy", "from": "/xxx", "path": "/yyy"},把某個屬性的值賦給目標(biāo)屬性。
remove 移動:{“op”: "move", "from": "/xxx", "path": "/yyy"},把源屬性的值賦值給目標(biāo)屬性,并把源屬性刪除或設(shè)成默認(rèn)值。
test測試:{“op”: "test", "path": "/xxx", "value": "xxx"},測試目標(biāo)屬性的值和指定的值是一樣的。
Asp.net mvc
接收J(rèn)sonPatch在Asp.net mvc
,可以使用JsonPatchDocument類型來處理json patch內(nèi)容,JsonPatchDocument可以將操作行為應(yīng)用到目標(biāo)實(shí)例里,得到操作之后的數(shù)據(jù)內(nèi)容。
在WebApiClient也提供一個JsonPatchDocument類型,該類型實(shí)現(xiàn)了IApiParameterable接口,在http請求之后,會執(zhí)行BeforeRequestAsync方法,完成組裝body的多個opration的數(shù)據(jù)json內(nèi)容。
以上就是WebApiClient的JsonPatch局部更新是怎樣的,小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。