1. 文章目的
隨著 WebApiClient 的不斷完善,越來越多開發(fā)者選擇WebApiClient替換原生的HttpClient,本文將介紹使用WebApiClient來完成JsonPatch提交的新特性。
2. json patch介紹
在服務(wù)端WebApi開發(fā)的時候,如果設(shè)計一個更新登錄用戶的個人信息的接口,用戶能更新昵稱、密碼、生日、性別等N多個字段,但用戶在實際使用中,可能是更新其中的一個或不確定多個字段。開發(fā)者往往會為難:對于客戶端沒有更新到的字段,應(yīng)該設(shè)置為什么值呢?一種是讓客戶端從服務(wù)器同步后再更新相關(guān)字段,一種是不更新的字段設(shè)置為null,服務(wù)器收到null的字段不更新,但這個還是有歧義(要更新為null的情況)。
json patch是為客戶端能夠局部更新服務(wù)端已存在的資源而設(shè)計的一種標(biāo)準(zhǔn)交互,在 RFC6902 里有詳細(xì)的介紹json patch,通俗來講有以下幾個要點:
以下為一個json patch請求的數(shù)據(jù)包:
PATCH /my/data HTTP/1.1Host: example.orgContent-Length: 326Content-Type: application/json-patch+jsonIf-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為操作的意思,分為以下幾種:
3. Asp.net mvc 接收J(rèn)sonPatch
在 Asp.net mvc ,可以使用JsonPatchDocument類型來處理json patch內(nèi)容,JsonPatchDocument可以將操作行為應(yīng)用到目標(biāo)實例里,得到操作之后的數(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;}
新聞熱點
疑難解答