Jackson前後端開發模式必備json利器

来源:https://www.cnblogs.com/isyuesen/archive/2023/06/02/17450005.html
-Advertisement-
Play Games

### 前言 json是我們現代互聯網程式最常用的交互格式,是否你在工作中會遇到前端說欄位不一致需要改的需求,是否遇到過資料庫欄位名與javaBean的規範不同,是否遇到過json與javaBean相互轉換時因為需求寫的土匪代碼,這些都可以用Jackson完成,我們經常和json打交道,而Jacks ...


前言

json是我們現代互聯網程式最常用的交互格式,是否你在工作中會遇到前端說欄位不一致需要改的需求,是否遇到過資料庫欄位名與javaBean的規範不同,是否遇到過json與javaBean相互轉換時因為需求寫的土匪代碼,這些都可以用Jackson完成,我們經常和json打交道,而Jackson就是幫助我們更好的處理json的框架,SpringBoot預設自帶,還有一款Fastjson,阿裡開源的,國內這兩種用的比較多,我選擇了Jackson,老牌穩定。
先來瞭解兩個概念:

  1. JSON序列化:Object -> JSONString
  2. JSON反序列化:JSONString -> Object

Jackson庫介紹

Jackson庫有兩個核心類:​ObjectMapper​​​和​​JsonNode​​。

​​ObjectMapper​​​類是Jackson庫中最重要的類,它提供了序列化和反序列化Java對象與JSON之間的轉換。​​ObjectMapper​​類的實例是線程安全的,可以在多線程環境中共用

​​JsonNode​​​類是一個抽象類,它代表了一個JSON節點。​​JsonNode​​​類有多個子類,例如​​ObjectNode​​​、​​ArrayNode​​​、​​ValueNode​​​等,分別對應JSON中的對象、數組和值。​​JsonNode​​類提供了方便的方法來讀取JSON節點的值。

註解

註解是我們最常用的方式,直接選擇常用的開搞,全註解 http://https://www.baeldung.com/jackson-annotations

適用序列化和反序列化

@JsonProperty

@JsonProperty 序列化與反序列化別名,作用於屬性上

  • @JsonProperty.value: 要使用的名稱(別名)
  • @JsonProperty.index:要使用的物理索引,如果數據格式(JSON 除外)是基於索引的 預設值-1
  • @JsonProperty.defaultValue: 定義為元數據的文本預設值。註意:核心數據綁定不使用這個值;它目前只暴露給擴展模塊。
  • @JsonProperty.required: 序列化與反序列化時候屬性是否必須要有,如果為true沒有的話會拋出異常,預設值 false

@JsonFormat

  • @JsonFormat 日期、時間、數字,序列化與反序列化
  • @JsonFormat.pattern:用於指定日期、時間、數字等的格式模式。例如,"yyyy-MM-dd" 表示日期格式為 "年-月-日"。預設為空字元串 ""。
  • @JsonFormat.shape:用於指定屬性的序列化和反序列化形狀。預設為 JsonFormat.Shape.ANY。常用的取值包括:
    JsonFormat.Shape.STRING:將屬性序列化為字元串。
    JsonFormat.Shape.NUMBER:將屬性序列化為數字。
    JsonFormat.Shape.ARRAY:將屬性序列化為數組。
    JsonFormat.Shape.OBJECT:將屬性序列化為對象。
  • @JsonFormat.locale:用於指定地區(Locale),在日期、時間格式化時可能會用到。預設為 JsonFormat.DEFAULT_LOCALE,系統預設地區
  • @JsonFormat.timezone:用於指定時區,對於日期和時間的處理往往與時區有關。預設為空字元串 "",系統預設時區
  • @JsonFormat.patternLocale:用於指定日期、時間格式模式的地區(Locale)。預設為 JsonFormat.DEFAULT_LOCALE,通常是 Java 虛擬機預設的地區(Locale)。
  • @JsonFormat.lenient:用於指定是否允許寬鬆的解析,例如接受部分格式不符合模式的輸入。預設為 false

如果將 lenient 屬性設置為 true,則在反序列化過程中可以允許一些非嚴格匹配的輸入。例如,如果輸入的日期字元串為 "2021-01",它並不符合完整的 "yyyy-MM-dd" 格式,但由於 lenient 設置為 true,Jackson 可以進行寬鬆解析,將其解釋為 2021 年 1 月的某個日期(如 2021 年 1 月 1 日)。

@JsonUnwrapped

@JsonUnwrapped 序列與反序列化時對象屬性是否需要展開在父對象上,Map不適用,Map用@JsonAnyGetter
例如:

public class User {
    private String name;
    @JsonUnwrapped
    private Address address;
}
public class Address {
    private String street;
    private String city;
}

結果

{
  "name": "John",
  "street": "123 Main St",
  "city": "New York"
}

適用序列化

@JsonPropertyOrder

@JsonPropertyOrder 序列化時排列排列順序

  • @JsonProperty.value: 屬性名
  • @JsonProperty.alphabetic:是否按字母順序排列

@JsonIgnore

@JsonIgnore 序列化時忽略的屬性,作用於屬性上

@JsonIgnoreProperties

@JsonIgnoreProperties 序列化忽略的屬性集合,作用於類上

  • @JsonIgnoreProperties.value :在序列化時,忽略列出的屬性
  • @JsonIgnoreProperties.ignoreUnknown:在反序列化時,忽略沒有 getter/setter 的屬性

@JsonIgnoreType

@JsonIgnoreType 忽略註釋類型的所有屬性,作用於類上

@JsonInclude

@JsonInclude 序列化時,值為規則這個屬性隱藏,作用於類和屬性上

  • @JsonInclude.value:規則 預設值JsonInclude.Include.ALWAYS
  • @JsonInclude.content:集合類型屬性規則 預設值JsonInclude.Include.ALWAYS
    JsonInclude.Include.ALWAYS:始終包含屬性,即使屬性值為 null。
    JsonInclude.Include.NON_NULL:僅在屬性值不為 null 時才包含屬性。
    JsonInclude.Include.NON_DEFAULT:僅在屬性值與預設值不相等時才包含屬性。
    JsonInclude.Include.NON_EMPTY:僅在屬性值不為 null 且不為空(例如空字元串或空集合)時才包含屬性。

@JsonAnyGetter

@JsonAnyGetter 註釋允許靈活地將Map屬性用作標準屬性平鋪在父對象上,適用序列化,作用於get方法上,返序列化用@JsonAnySetter
例如:

@Data
public class OrderDetails {
    Map<String, String> tempMap = new HashMap<String, String>(){{
        put("temp","temp");
        put("temp1","temp1");
    }};

    @JsonAnyGetter
    public Map<String, String> getTempMap() {
        return tempMap;
    }
}

結果

{
    "temp": "temp",
    "temp1": "temp1"
}

@JsonGetter

@JsonGetter 序列化時別名,作用於get方法上

@JsonView

@JsonView 序列與反序列化 分組選擇需要顯示的屬性
例子:

@Data
public class OrderDetails {
    public interface UserSimpleView {};
    public interface UserDetailView {};

    @JsonView({UserSimpleView.class,UserDetailView.class})
    String name = "yues";
    @JsonView(UserDetailView.class)
    String password = "123";
}

結果:

@JsonView(OrderDetails.UserSimpleView.class)
@RequestMapping("/add")
public Object add(@RequestBody OrderDetails orderDetails) {
//        {
//            "name": "yues"
//        }
	return orderDetails;
}
@JsonView(OrderDetails.UserDetailView.class)
@RequestMapping("/add")
public Object add(@RequestBody OrderDetails orderDetails) {
//        {
//            "name": "yues",
//            "password": "123"
//        }
	return orderDetails;
}

@JsonRootName

@JsonRootName 包一層
例子:

@Data
@JsonRootName("user")
public class OrderDetails {
    String name = "yues";
}

{
  "user":  {
     "name": "yues"
  },
}

@JsonSerialize

@JsonSerialize 自定義序列化器

  • using:指定要使用的自定義序列化器類。該參數接受一個實現了 Jackson 的 JsonSerializer 介面的類。您可以編寫自定義的序列化器類來控制屬性的序列化行為。

    值為null不會執行

  • as:在序列化過程中,指定使用的序列化器類型。預設情況下,Jackson 會根據屬性的類型來選擇合適的序列化器。使用 as 參數可以強制指定序列化器的類型,覆蓋預設的選擇。
  • keyUsing:在序列化過程中,指定用於序列化屬性鍵(如果屬性是一個 Map 或類似結構的鍵值對)的自定義序列化器。該參數接受一個實現了 Jackson 的 JsonSerializer 介面的類。
  • contentUsing:在序列化過程中,指定用於序列化屬性值(如果屬性是一個 Collection 或類似結構的集合)的自定義序列化器。該參數接受一個實現了 Jackson 的 JsonSerializer 介面的類。
  • nullsUsing:在序列化過程中,指定用於處理屬性值為 null 的自定義序列化器。該參數接受一個實現了 Jackson 的 JsonSerializer 介面的類。通過設置 nullsUsing 參數,您可以定義在屬性值為 null 時應該採取的序列化行為。

反序列化

@JsonSetter

@JsonGetter 反序列化時別名,作用於set方法上

@JsonAlias

@JsonAlias 反序列化時別名可以應用於類的屬性上且可以指定多個

@JsonDeserialize

@JsonDeserialize 自定義反序列化器

  • using:指定要使用的自定義反序列化器類。該屬性接受一個實現了 Jackson 的 JsonDeserializer 介面的類。您可以編寫自定義的反序列化器類來控制屬性的反序列化行為。
  • contentUsing:在反序列化過程中,指定用於處理屬性值(如果屬性是一個 Collection 或類似結構的集合)的自定義反序列化器。該屬性接受一個實現了 Jackson 的 JsonDeserializer 介面的類。
  • keyUsing:在反序列化過程中,指定用於處理屬性鍵(如果屬性是一個 Map 或類似結構的鍵值對)的自定義反序列化器。該屬性接受一個實現了 Jackson 的 JsonDeserializer 介面的類。
  • contentAs:在反序列化過程中,指定用於處理屬性值(如果屬性是一個 Collection 或類似結構的集合)的類型。通過設置 contentAs 屬性,您可以強制 Jackson 使用指定的類型進行屬性值的反序列化。

自定義註解

例子

@Retention(RetentionPolicy.RUNTIME)
@JacksonAnnotationsInside
@JsonInclude(Include.NON_NULL)
@JsonPropertyOrder({ "name", "id", "dateCreated" })
@JsonDeserialize //自定義反序列化
@@JsonSerialize  //自定義序列化
public @interface CustomAnnotation {}

不用註解ObjectMapper對象

以上的註解都可以使用ObjectMapper對象來配置,先有ObjectMapper才有的這些註解,上面的註解都是使用ObjectMapper來完成的,在SpringBoot中我們還可以用ObjectMapper Bean來達到全局配置,當然也可以用配置文件。在日常的開發工作中,我們經常全局制定日期格式、駝峰_轉換等等。
這裡就不多做使用ObjectMapper來詳細說,貼一些常用的方法吧

ObjectMapper mapper = new ObjectMapper()
mapper.enable(序列化配置);
mapper.configure(反序列化配置);
// 將字元串、byte[]轉換為對象 序列化
mapper.readValue(jsonString, User.class);
// 此方法更靈活,可以只將用戶感興趣的Json串信息值提取出來 序列化
mapper.readTree(test);

// 將對象轉換為json字元串 反序列化
mapper.writeValueAsString(user);
// 將對象轉換為byte 反序列化
mapper.writeValueAsBytes(user)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 雖然漢字#起名名字#的資料庫已經有一些,比如7千多漢字起名參考大典ACCESS資料庫、漢字起名中文起名寶寶起名ACCESS資料庫,但是今天發現了一個資料庫,他是在《7千多漢字起名參考大典》的基礎上增加了30萬個男孩女孩的名字實例。非常適合於比如固定了名字的第二個字,取第三個字時一查就有參考。 漢字表 ...
  • 燈謎,即寫在彩燈上面的謎語,又叫“燈虎”。猜燈謎又叫“射燈虎”。謎語來源於民間口謎,後經文人加工成為謎,它在中國源遠流長。春秋戰國時期,出現了“隱語”或“庾辭”。秦漢時則成為一種書面創作。三國時代,猜謎盛行。在宋代出現了燈謎。人們將謎條繫於五彩花燈上,供人猜射。明清時代,猜燈謎在民間十分流行。 按“ ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 面試官:“HTTPS的加密過程你知道麽?” 我:“那肯定知道啊。” 面試官:“那你知道什麼情況下 HTTPS 不安全麽” 我:“這....” 越面覺得自己越菜,繼續努力學習!!! 什麼是中間人攻擊? 中間人攻擊(MITM)在密碼學和電腦 ...
  • # VuePress2.0構建項目文檔系統 參考TerraMours 官網。[https://terramours.site/](https://terramours.site/) 文件結構參考: ![image-20230530170541496](https://www.raokun.top/u ...
  • 當我們在電腦中使用浮點數進行計算時,特別是在使用二進位表示浮點數時,可能會出現舍入誤差。這是由於電腦使用有限的位數來表示浮點數,而某些十進位數無法精確地表示為有限的二進位數。 0.1 和 0.2 都是無限迴圈的二進位數,在轉換為浮點數時並不能完全準確地表示。將它們相加時,可能會出現舍入誤差。因此 ...
  • ## 1. 背景 - 業務背景:CRM系統隨著各業務條線對線索精細化分配的訴求逐漸增加,各個條線的流向規則會越來越複雜,各個條線甚至整個CRM的線索流轉規則急需一種樹形的可視化的圖來表達。 - 技術背景:在開發之前考慮了三種方案,原生canvas、fabric以及G6,三種方案各有優劣勢 |  | ...
  • 上一篇:微服務架構基本原理學習筆記(一) 三、微服務架構 從一個已有的單體架構的應用程式開始進行微服務架構的重構往往是一個不錯的選擇。隨著業務量和功能的增加,我們可以考慮使用微服務架構來擴充應用程式中原有的功能,或者每次添加新功能時,都為其創建一個新的微服務。這比從一開始就選擇使用微服務架構進行設計 ...
  • EasyExcel是一個基於Java的、快速、簡潔、解決大文件記憶體溢出的Excel處理工具。 他能讓你在不用考慮性能、記憶體的等因素的情況下,快速完成Excel的讀、寫等功能。 # 快速入門 導入依賴 ~~~xml com.alibaba easyexcel 3.1.1 ~~~ # 寫 Excel # ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...