JSON 與 Java 對象之間的轉化

来源:https://www.cnblogs.com/god23bin/archive/2023/03/27/json-to-java.html
-Advertisement-
Play Games

在現在的日常開發中,不管前端還是後端,JSON 格式的數據是用得比較多的,甚至可以說無處不在。在某些業務場景下也是需要用到 JSON 的,特別是 JSON 與 Java 對象之間的轉化。 ...


前言

在現在的日常開發中,不管前端還是後端,JSON 格式的數據是用得比較多的,甚至可以說無處不在。

接觸最多的就是 POST 請求中傳遞的數據一般以 JSON 的格式放在請求體中,而且服務端各種 API 返回的數據,在響應體中也基本都是以 JSON 格式的數據進行返回的,這也是 RESTful 風格的體現之一。

當然,不止是請求與響應的過程中使用到 JSON,在某些業務場景下也是需要用到 JSON 的,特別是 JSON 與 Java 對象之間的轉化

所以,對於 Java 開發的我們來說,JSON 格式的數據與 Java 對象之間的轉化是必會的。

轉化的工具

主流的轉化工具有如下幾種,一般項目中建議只選其中一種,目前好評最多的感覺就是 Jackson 了。

  • Jackson

  • FastJson

  • Gson

  • Hutool

準備的 JSON 字元串和 List

為了方便演示,這裡給出一個 JSON 字元串:

String jsonStr = "{\"name\" : \"GTA5\", \"price\" : 54.5}";

這裡給出一個 List<Game>

Game game1 = Game.builder().name("NBA2K23").price(new BigDecimal("198.0")).build();
Game game2 = Game.builder().name("Sim City4").price(new BigDecimal("22.5")).build();
List<Game> gameList = new ArrayList<>();
gameList.add(game1);
gameList.add(game2);

Jackson

我們需要藉助 Jackson 提供的 ObjectMapper 對象來完成轉化:

ObjectMapper objectMapper = new ObjectMapper();

將 JSON 字元串 轉成 Java 對象:readValue

使用 readValue 方法,第一個參數是 JSON 字元串,第二個參數是轉化的目標類的類型。

// 將 JSON 字元串 轉成 Java 對象
Game game = objectMapper.readValue(jsonStr, Game.class);

將 Java 對象轉成 JSON 字元串:writeValueAsString

使用 writeValueAsString 方法,接受一個 Java 對象,返回一個 JSON 字元串。

// 將 Java 對象轉成 JSON 字元串
String gameJson = objectMapper.writeValueAsString(game);

將 List 轉成 JSON 字元串:writeValueAsString

同樣使用 writeValueAsString 方法。

// 將 List<Game> 轉成 JSON 字元串
String gameListJson = objectMapper.writeValueAsString(gameList);

將 JSON 字元串 轉成 List:readValue

使用 readValue 方法,第一個參數是 JSON 字元串,第二個參數是轉化的目標 TypeReference(類型參照)對象,這裡指定其泛型為 List<Game>

// 將 JSON 字元串 轉成 List<Game>
List<Game> gameListFromJson = objectMapper.readValue(gameListJson, new TypeReference<List<Game>>() {});

總結

從 JSON 到 Java 對象,使用 readValue 方法。

從 Java 對象到 JSON,使用 writeValueAsString 方法。

FastJson

我們需要藉助 FastJson 提供的 JSONObject 對象來完成轉化。

將 JSON 字元串 轉成 Java 對象:parseObject

使用 parseObject 方法,將 JSON 字元串解析(轉化)成 Java 對象,第一個參數是 JSON 字元串,第二個參數是目標類的類型。

// 將 JSON 字元串 轉成 Java 對象
Game game = JSONObject.parseObject(jsonStr, Game.class);

將 Java 對象轉成 JSON 字元串:toJSONString

使用 toJSONString 方法,將 Java 對象直接轉成 JSON 字元串,接受一個 Java 對象,返回對應的 JSON 字元串。

// 將 Java 對象轉成 JSON 字元串
String gameJson = JSONObject.toJSONString(game);

將 List 轉成 JSON 字元串:toJSONString

同理,可以直接丟一個 List 對象給 toJSONString 方法,把 List 轉成 JSON 字元串。

// 將 List<Game> 轉成 JSON 字元串
String gameListJson = JSONObject.toJSONString(gameList);

將 JSON 字元串 轉成 List:parseArray

使用 parseArray 方法,將 JSON 字元串解析成 List。2.0 版本需要調用 toJavaList 方法,得到最後的 List

// 將 JSON 字元串 轉成 List<Game>
// fastjson 1.2.x 版本:List<Game> gameListFromJson = JSONObject.parseArray(gameListJson, Game.class);
List<Game> gameListFromJson = JSONArray.parseArray(gameListJson).toJavaList(Game.class);

總結

JSON 轉成 Java Bean 使用 parseObject 方法,轉成 List 使用 parseArray 方法。

任意對象轉成 JSON,則使用 toJSONString 方法。

Gson

我們需要藉助 Gson 對象來完成轉化:

Gson gson = new Gson();

將 JSON 字元串 轉成 Java 對象:fromJson

使用 fromJson 方法,兩個參數的定義也是和上面兩個一樣的。

// 將 JSON 字元串 轉成 Java 對象
Game game = gson.fromJson(jsonStr, Game.class);

將 Java 對象轉成 JSON 字元串:toJson

使用 toJson 方法,接受一個 Java 對象,然後返回對應的 JSON 字元串。

// 將 Java 對象轉成 JSON 字元串
String gameJson = gson.toJson(game);

將 List 轉成 JSON 字元串:toJson

List 也是同理,使用 toJson 方法。

// 將 List<Game> 轉成 JSON 字元串
String gameListJson = gson.toJson(gameList);

將 JSON 字元串 轉成 List:fromJson

這裡和 Jackson 的也是類似,第二個參數使用 TypeToken 對象指定轉化的目標類型為 List<Game>

// 將 JSON 字元串 轉成 List<Game>
List<Game> gameListFromJson = gson.fromJson(gameListJson, new TypeToken<List<Game>>() {}.getType());

總結

從 JSON 到 Java 對象,使用 fromJson 方法。

從 Java 對象到 JSON,使用 toJson 方法。

Hutool

我們需要藉助 Hutool 提供的 JSONUtil 對象來完成轉化。

將 JSON 字元串 轉成 Java 對象:toBean

使用 toBean 方法,還是同樣的,接受的兩個參數,一個字元串,一個目標類的類型。

// 將 JSON 字元串 轉成 Java 對象
Game game = JSONUtil.toBean(jsonStr, Game.class);

將 Java 對象轉成 JSON 字元串:toJsonStr

使用 toJsonStr 方法,接受一個 Java 對象,返回一個 JSON 字元串。

// 將 Java 對象轉成 JSON 字元串
String gameJson = JSONUtil.toJsonStr(game);

將 List 轉成 JSON 字元串:toJsonStr

同理,也是 toJsonStr 方法。

// 將 List<Game> 轉成 JSON 字元串
String gameListJson = JSONUtil.toJsonStr(gameList);

將 JSON 字元串 轉成 List:toList

使用 toList 方法,和 toBean 方法接受的參數一樣。

// 將 JSON 字元串 轉成 List<Game>
List<Game> gameListFromJson = JSONUtil.toList(gameListJson, Game.class);

總結

JSON 轉成 Java Bean 使用 toBean 方法,轉成 List 使用 toList 方法。

任意對象轉成 JSON,則使用 toJsonStr 方法。

最後的最後

由本人水平所限,難免有錯誤以及不足之處, 屏幕前的靚仔靚女們 如有發現,懇請指出!

最後,謝謝你看到這裡,謝謝你認真對待我的努力,希望這篇博客對你有所幫助!

你輕輕地點了個贊,那將在我的心裡世界增添一顆明亮而耀眼的星!


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

-Advertisement-
Play Games
更多相關文章
  • 定義 定義一系列的演算法,將他們一個個封裝起來,使他們直接可以相互替換。 演算法:就是寫的邏輯可以是你任何一個功能函數的邏輯 封裝:就是把某一功能點對應的邏輯給抽出來 可替換:建立在封裝的基礎上,這些獨立的演算法可以很方便的替換 通俗的理解就是,把你的演算法(邏輯)封裝到不同的策略中,在不同的策略中是互相獨 ...
  • 訪問者模式(Visitor Pattern)是一種行為型設計模式,用於將操作與其所操作的對象分離開來。該模式的核心思想是將操作封裝在一個訪問者對象中,而不是分散在各個對象中。通過將操作與對象分離開來,訪問者模式可以在不修改對象結構的情況下,添加新的操作。 在前端開發中,訪問者模式通常用於處理DOM樹 ...
  • mounted: () { this.getList('', (data) => { console.log(data); }) } methods: { getList (condition) { get_list({...condition}).then(res => { if (res.dat ...
  • 在Vue $mount過程中,我們需要把模版編譯成render函數,整體實現可以分為三部分: parse、optimize、codegen。 ...
  • 1. 響應式編程 1.1. 使用基於事件的範式處理非同步數據流 1.2. 和非同步編程提供了相同的性能優勢 1.3. 能夠擴展程式(特別是擴展I/O)以處理很多連接和數據源 2. 非阻塞I/O 2.1. 有效擴展伺服器的基礎 2.2. 允許伺服器用相對較少的線程處理相對較多的連接 2.2.1. 傳統的服 ...
  • 關於商業認知 2022 年復盤了過去幾年的項目經歷:很多項目商業都沒開始就死了,能商業化閉環 & 能持續一段時間的一隻手數量都沒有。 從 2022 年幾個月陸續復盤中,收穫了不少商業相關心得: 心得:一定要選合適自己方向的項目 以前我對戰略、方向的思考是極少的,很容易陷入達克效應(鄧寧-克魯格效應) ...
  • 本文已經收錄到Github倉庫,該倉庫包含電腦基礎、Java基礎、多線程、JVM、資料庫、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分散式、微服務、設計模式、架構、校招社招分享等核心知識點,歡迎star~ Github地址 大家好,我是大彬~ 今天給大家分 ...
  • 使用 VLD 記憶體泄漏檢測工具輔助開發時整理的學習筆記。本篇介紹 VLD 配置文件中配置項 MaxDataDump 的使用方法。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...