詳解WebApiClient的JsonPatch局部更新
1. 文章目的
隨著 WebApiClient 的不斷完善,越來越多開發(fā)者選擇WebApiClient替換原生的HttpClient,本文將介紹使用WebApiClient來完成JsonPatch提交的新特性。
2. json patch介紹
在服務(wù)端WebApi開發(fā)的時(shí)候,如果設(shè)計(jì)一個(gè)更新登錄用戶的個(gè)人信息的接口,用戶能更新昵稱、密碼、生日、性別等N多個(gè)字段,但用戶在實(shí)際使用中,可能是更新其中的一個(gè)或不確定多個(gè)字段。開發(fā)者往往會(huì)為難:對(duì)于客戶端沒有更新到的字段,應(yīng)該設(shè)置為什么值呢?一種是讓客戶端從服務(wù)器同步后再更新相關(guān)字段,一種是不更新的字段設(shè)置為null,服務(wù)器收到null的字段不更新,但這個(gè)還是有歧義(要更新為null的情況)。
json patch是為客戶端能夠局部更新服務(wù)端已存在的資源而設(shè)計(jì)的一種標(biāo)準(zhǔn)交互,在 RFC6902 里有詳細(xì)的介紹json patch,通俗來講有以下幾個(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類型來處理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);
5. 結(jié)束語
博主為WebApiClient庫的作者,本文向讀者介紹了JsonPatch的基本知識(shí),以及如何在WebApiClient提交JsonPatch,歡迎大家給WebApiClient提建議。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
利用MS AJAX注冊(cè)Javascript命名空間并創(chuàng)建類
利用MS AJAX注冊(cè)Javascript命名空間并創(chuàng)建類...2007-10-10ASP.NET MVC5網(wǎng)站開發(fā)我的咨詢列表及添加咨詢(十二)
這篇文章主要為大家詳細(xì)介紹了ASP.NET MVC5網(wǎng)站開發(fā)我的咨詢列表及添加咨詢,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2015-09-09HttpWebRequest和HttpWebResponse用法小結(jié)
在每個(gè)系統(tǒng)出寫入報(bào)告錯(cuò)誤代碼(找個(gè)合理的理由,比如系統(tǒng)免費(fèi)升級(jí)) -> 自家服務(wù)器接收并處理錯(cuò)誤報(bào)告 -> 反饋用戶(解決掉BUG就行,不要太聲揚(yáng))2011-09-09.NET?Core利用?AsyncLocal?實(shí)現(xiàn)共享變量的代碼詳解
在Web?應(yīng)用程序中,我們經(jīng)常會(huì)遇到這樣的場(chǎng)景,如用戶信息,租戶信息本次的請(qǐng)求過程中都是固定的,我們希望是這種信息在本次請(qǐng)求內(nèi),一次賦值,到處使用。本文就來探討一下,如何在.NET?Core?下去利用AsyncLocal?實(shí)現(xiàn)全局共享變量2022-04-04Razor TagHelper實(shí)現(xiàn)Markdown轉(zhuǎn)HTML的方法
下面小編就為大家分享一篇Razor TagHelper實(shí)現(xiàn)Markdown轉(zhuǎn)HTML的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-12-12使用微信PC端的截圖dll庫實(shí)現(xiàn)微信截圖功能
這篇文章主要為大家詳細(xì)介紹了使用微信PC端的截圖dll庫實(shí)現(xiàn)微信截圖功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06asp.net JavaScript插件 JavaScript Function Outliner
一個(gè)JavaScript Function Outliner插件 第四版本 支持內(nèi)嵌javascript,且可以對(duì)javascript進(jìn)行壓縮2008-07-07ASP.NET Session的七點(diǎn)認(rèn)識(shí)小結(jié)
ASP.NET Session的使用當(dāng)中我們會(huì)遇到很多的問題,那么這里我們來談下經(jīng)常出現(xiàn)的一些常用ASP.NET Session的理解2011-07-07