javascript
JSON补丁:JSON-P 1.1概述系列
Java EE 8包括對JSON處理API的更新,并使其與JSON的最新IEFT標準保持同步。 他們是:
- JSON指針 RFC 6901
- JSON補丁 RFC 6902
- JSON合并修補程序RFC 7396
我將在這個迷你系列中涵蓋這些主題。
入門
要開始使用JSON-P,您將需要Maven中央存儲庫中的以下依賴項。
<dependency><groupId>javax.json</groupId><artifactId>javax.json-api</artifactId><version>1.1</version> </dependency><dependency><groupId>org.glassfish</groupId><artifactId>javax.json</artifactId><version>1.1</version> </dependency>JSON補丁
JSON修補程序表示要應用于目標JSON文檔的一系列操作。 這些操作以JSON-Pointer表示法格式化,并且可以執行: 添加 , 復制 , 移動 , 刪除 , 替換和測試操作。
JsonPatchBuilder接口是該API的網關,并且是通過Json類中的靜態方法createPatchBuilder()創建的。 JSON指針表達式傳遞給其中一種操作方法,并應用于JSON文檔。
替換操作
替換操作由replace()方法執行,并將要替換的元素的位置傳遞給它(表示為JSON指針表達式)和替換值。
{ "title": "Java EE: Only What's New", "author": "Alex Theedom", "chapters": ["Chapter 1: Java EE 8 What’s New Overview","Chapter 2: Java API for JSON Binding 1.0 (JSR 367)","Chapter 3: Java EE Security API 1.0 (JSR 375)" ], "released": true, "pages": 300, "sourceCode": {"repositoryName": "Java-EE-8-Only-Whats-New","url": "github.com/readlearncode/" }, "otherBooks": [{"title": "Professional Java EE Design Patterns","length": 350} ] }JsonObject jsonObject = ... create JSONObject from JSON document ...;在下面的代碼段中(在上面的JSON文檔中),使用JSON指針表達式/ chapters / 0表示的chapters數組的第一個元素的值替換為Chapter 1:Introduction的值。
JsonPatchBuilder builder = Json.createPatchBuilder();JsonPatch jsonPatch = builder.replace("/chapters/0", "Chapter 1: Introduction").build();JsonObject newJsonObject = jsonPatch.apply(jsonObject);apply()方法返回JsonStructure類的實例。
添加和刪??除操作
JSON修補程序的一個關鍵功能是能夠將多個操作鏈接在一起,并將它們順序應用于先前的修補結果的功能。 如果在修補操作期間引發異常,它將停止操作,并且不會對原始JSON文檔進行任何更改。
下面的代碼示例顯示了如何在JSON文檔中添加和刪除元素。
JsonObject newJsonObject = Json.createPatchBuilder().add("/chapters/3", "Chapter 4: Servlets 4.0").remove("/released").build().apply(jsonObject);add()方法采用JSON指針表達式,該表達式標識要在其中插入新數據的元素。 第二個元素是要插入的新數據。
要刪除元素,請將要刪除的元素的JSON指針傳遞給remove()方法。
移動和復制操作
移動操作需要兩個JSON指針表達式:
- 一個元素移動,
- 一個用于將值移動到的目標位置。
目標位置必須已經存在,并且遵循與添加操作相同的邏輯,從這個意義上說,目標位置是通過將元素移動到指定位置來將其移動。 有效地將所有元素下移一個位置。
復制操作將一個元素的值替換為另一個元素的值。 此操作還需要兩個JSON指針表達式:一個用于源值,一個用于目標位置。
下面的代碼片段將三個操作鏈接在一起:兩個移動操作和一個復制操作。
JsonObject newJsonObject = Json.createPatchBuilder().move("/chapters/0", "/chapters/2").move("/chapters/2", "/chapters/1").copy("/otherBooks/0/length", "/pages").build().apply(jsonObject);移動操作將位于章數組第三位置的值移動到第一位置,然后將第二位置的元素移動到第三位置。 復制操作會將 pages鍵的值復制到otherBooks數組中第一個元素的length鍵。
測試操作
測試操作確定是否在JSON文檔中設置了指定的值。 如果測試失敗,補丁操作將停止,否則它將繼續并完成剩余的操作。
在代碼段中,對元素/ pages進行了測試。 如果其值為300,則復制操作將繼續,否則將拋出JsonException 。
JsonObject newJsonObject = Json.createPatchBuilder().test("/pages", 300).copy("/otherBooks/0/length", "/pages") // destination, source.build().apply(jsonObject);結論
好了,這就是本微型系列文章的第二篇有關JSON處理的新功能。
目前為止就這樣了。
翻譯自: https://www.javacodegeeks.com/2018/04/get-to-know-json-patch-json-p-1-1-overview-series.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的JSON补丁:JSON-P 1.1概述系列的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 在Spring WebFlux中创建多个
- 下一篇: 24.98 万元起,AITO 问界新 M