這篇文章給大家介紹怎么在WebApiClient中使用JsonPatch實(shí)現(xiàn)局部更新,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

json patch是為客戶端能夠局部更新服務(wù)端已存在的資源而設(shè)計(jì)的一種標(biāo)準(zhǔn)交互,在 RFC6902 里有詳細(xì)的介紹json patch,通俗來(lái)講有以下幾個(gè)要點(diǎn):
使用HTTP PATCH請(qǐng)求方法;
請(qǐng)求body為描述多個(gè)opration的數(shù)據(jù)json內(nèi)容;
請(qǐng)求的Content-Type為application/json-patch+json;
以下為一個(gè)json patch請(qǐng)求的數(shù)據(jù)包:
PATCH /my/data HTTP/1.1
Host: example.org
Content-Length: 326
Content-Type: application/json-patch+json
If-Match: "abc123"
[
{ "op": "test", "path": "/a/b/c", "value": "foo" },
{ "op": "remove", "path": "/a/b/c" },
{ "op": "add", "path": "/a/b/c", "value": [ "foo", "bar" ] },
{ "op": "replace", "path": "/a/b/c", "value": 42 },
{ "op": "move", "from": "/a/b/c", "path": "/a/b/d" },
{ "op": "copy", "from": "/a/b/d", "path": "/a/b/e" }
]op為操作的意思,分為以下幾種:
add 添加:{“op”: "add", "path": "/xxx", "value": "xxx"},如果該屬性不存,那么就添加該屬性,如果屬性存在,就改變屬性的值。
remove 刪除:{“op”: "remove", "path": "/xxx"},刪除某個(gè)屬性,或把它設(shè)為默認(rèn)值(例如空值)。
replace 替換:{“op”: "replace", "path": "/xxx", "value": "xxx"},改變屬性的值,也可以理解為先執(zhí)行了刪除,然后進(jìn)行添加。
copy 復(fù)制:{“op”: "copy", "from": "/xxx", "path": "/yyy"},把某個(gè)屬性的值賦給目標(biāo)屬性。
remove 移動(dòng):{“op”: "move", "from": "/xxx", "path": "/yyy"},把源屬性的值賦值給目標(biāo)屬性,并把源屬性刪除或設(shè)成默認(rèn)值。
test測(cè)試:{“op”: "test", "path": "/xxx", "value": "xxx"},測(cè)試目標(biāo)屬性的值和指定的值是一樣的。
3. Asp.net mvc 接收J(rèn)sonPatch
在 Asp.net mvc ,可以使用JsonPatchDocument類型來(lái)處理json patch內(nèi)容,JsonPatchDocument可以將操作行為應(yīng)用到目標(biāo)實(shí)例里,得到操作之后的數(shù)據(jù)內(nèi)容。
[HttpPatch]
public UserInfo Patch([FromBody] JsonPatchDocument<UserInfo> doc)
{
var user = new UserInfo
{
Account = "_Account",
Password = "_Password",
Email = "_Email"
};
doc.ApplyTo(user);
return user;
}4. WebApiClient提交JsonPatch
在WebApiClient也提供一個(gè)JsonPatchDocument類型,該類型實(shí)現(xiàn)了IApiParameterable接口,在http請(qǐng)求之后,會(huì)執(zhí)行BeforeRequestAsync方法,完成組裝body的多個(gè)opration的數(shù)據(jù)json內(nèi)容,使用方法如下:
public interface IPatchApi : IHttpApi
{
[HttpPatch("http://localhost:7171/api/userinfo")]
Task<string> PatchAsync(JsonPatchDocument<UserInfo> doc);
}
var doc = new JsonPatchDocument<UserInfo>();
doc.Replace(item => item.Account, "laojiu");
doc.Replace(item => item.Email, "laojiu@qq.com");
var client = HttpApiClient.Create<IPatchApi>();
await client.PatchAsync(doc);關(guān)于怎么在WebApiClient中使用JsonPatch實(shí)現(xiàn)局部更新就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
新聞標(biāo)題:怎么在WebApiClient中使用JsonPatch實(shí)現(xiàn)局部更新-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)路徑:http://chinadenli.net/article46/edghg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、網(wǎng)站排名、外貿(mào)網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化、網(wǎng)頁(yè)設(shè)計(jì)公司、網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容