91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何構建一個JSON字符串

發布時間:2021-01-21 17:08:26 來源:億速云 閱讀:176 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關如何構建一個JSON字符串,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

一、alibaba 的 Fastjson

1.Fastjson 是一個以 Java 語言編寫的 JSON 處理器,由阿里巴巴公司開發,功能強大。

要使用第三方的工具當然要導入 jar 包了,只需導入 fastjson-1.2.8.jar 即可,jar 包的獲取,大家可以直接去網上下載 ,也可以聯系本人。

先來一個 fastjson 的簡單實例吧,如下代碼構造了一個 Customer 的實例,并將此實例轉化成為 JSON 字符串,調用了 com.alibaba.fastjson.JSON 的 toJSONString() 方法,將 Customer 實例傳入

@Test
public void test1() {
 
 Customer customer = new Customer();
 customer.setId(1);
 customer.setCustName("Tom");
 customer.setAddress("BeiJing");
 
 String jsonStr = JSON.toJSONString(customer);
 System.out.println(jsonStr);
}

打印結果:{"address":"BeiJing","custName":"Tom","id":1}

再來一個小測試,將一個 List 的 Customer 的集合轉換為 JSON 字符串,22 行還是直接調用 JSON 的 toJSONString() 方法,將 List 集合傳入即可

/**
* 將 List 集合轉換為 JSON 字符串
*/
@Test
public void test2() {
 List<Customer> lists = new ArrayList<>();
 
 Customer customer = new Customer();
 customer.setId(1);
 customer.setCustName("Tom");
 customer.setAddress("BeiJing");
 
 lists.add(customer);
 
 Customer customer2 = new Customer();
 customer2.setId(1);
 customer2.setCustName("Bob");
 customer2.setAddress("ShangHai");
 
 lists.add(customer2);
 
 String jsonStr = JSON.toJSONString(lists);
 System.out.println(jsonStr);
}

打印結果:[{"address":"BeiJing","custName":"Tom","id":1},{"address":"ShangHai","custName":"Bob","id":1}]

2. 深入研究一下,我們看下面這種情況:3 行創建了一個 List 的 Customer 集合,10 和 11 行進行了一個重復的 add 操作,那么打印結果是什么樣的呢?

@Test
public void test3() {
 List<Customer> lists = new ArrayList<>();

 Customer customer = new Customer();
 customer.setId(1);
 customer.setCustName("Tom");
 customer.setAddress("BeiJing");

 lists.add(customer);
 lists.add(customer);
 
 String jsonStr = JSON.toJSONString(lists);
 System.out.println(jsonStr);

}

打印結果:[{"address":"BeiJing","custName":"Tom","id":1},{"$ref":"$[0]"}],大家看,第二個 Customer 實例沒有打印出,這就證明了 fastjson 默認禁止循環的引用,如果想改變這種情況,需要在 JSON 的 toJSONString() 方法中傳遞第二個參數 SerializerFeature.DisableCircularReferenceDetect 即可解決,如下:

@Test
public void test3() {
  List<Customer> lists = new ArrayList<>();

  Customer customer = new Customer();
  customer.setId(1);
  customer.setCustName("Tom");
  customer.setAddress("BeiJing");

  lists.add(customer);
  lists.add(customer);
 
  String jsonStr = JSON.toJSONString(lists, SerializerFeature.DisableCircularReferenceDetect);
  System.out.println(jsonStr);

}

此時的打印結果為:[{"address":"BeiJing","custName":"Tom","id":1},{"address":"BeiJing","custName":"Tom","id":1}],建議以后再使用 JSON 的 toJSONString() 方法時將第二個參數添加上

3.再深入一點,來看一個常見的問題,Department 和 Manager 類維護雙向一對一的關聯關系,Department 類中有 Manager 類的引用,Manager 類中有 Department 類的引用,來看如下代碼:在 11 和 12 行設置了關聯關系,14 行和 15 行進行 JSON 字符串的轉換,結果會怎樣呢?

  @Test
 public void test4() {
 Manager mgr = new Manager();
 mgr.setMgrId(1);
 mgr.setMgrName("Tom");
 
 Department dept = new Department();
 dept.setDeptId(2);
 dept.setDeptName("DEV");
 
 mgr.setDept(dept);
 dept.setManager(mgr);
 
 String jsonStr = JSON.toJSONString(dept, SerializerFeature.DisableCircularReferenceDetect);
// String jsonStr = JSON.toJSONString(mgr, SerializerFeature.DisableCircularReferenceDetect);
 System.out.println(jsonStr);
 }

答案是,拋出了異常,常見的 java.lang.StackOverflowError,拋異常的原因是雙方都維護關聯關系進入了死循環,那么如何解決這個問題呢?可以在一方添加 @JSONField(serialize=false) 注解,7 行所示,即可解決

public class Department {
 
 private Integer deptId;
 
 private String deptName;
 
 @JSONField(serialize=false)
 private Manager manager;

 public Integer getDeptId() {
 return deptId;
 }

 public void setDeptId(Integer deptId) {
 this.deptId = deptId;
 }

 public String getDeptName() {
 return deptName;
 }

 public void setDeptName(String deptName) {
 this.deptName = deptName;
 }

 public Manager getManager() {
 return manager;
 }

 public void setManager(Manager manager) {
 this.manager = manager;
 }
 
}

打印結果為:{"dept":{"deptId":2,"deptName":"DEV"},"mgrId":1,"mgrName":"Tom"},結果也很令人滿意。

4.最后提供一個 fastjson 的工具類,開發時可以直接使用,供大家參考

package qi.ssh.utils;

import java.io.IOException;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;

import javax.servlet.http.HttpServletResponse;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;

public class FastJsonUtil {
 
 /**
 * 將對象轉成json串
 * @param object
 * @return
 */
 public static String toJSONString(Object object){
 //DisableCircularReferenceDetect來禁止循環引用檢測
 return JSON.toJSONString(object,SerializerFeature.DisableCircularReferenceDetect);
 }
 
 //輸出json
 public static void write_json(HttpServletResponse response,String jsonString)
 {
 response.setContentType("application/json;utf-8");
 response.setCharacterEncoding("UTF-8");
 try {
  response.getWriter().print(jsonString);
 } catch (IOException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 } 
 }
 /**
 * ajax提交后回調的json字符串
 * @return
 */
 public static String ajaxResult(boolean success,String message)
 {
 Map map=new HashMap();
 map.put("success", success);//是否成功
 map.put("message", message);//文本消息
 String json= JSON.toJSONString(map); 
 return json;
 }
 

 /**
 * JSON串自動加前綴
 * @param json 原json字符串
 * @param prefix 前綴
 * @return 加前綴后的字符串
 */

 public static String JsonFormatterAddPrefix(String json,String prefix,Map<String,Object> newmap)
 {
 if(newmap == null){
  newmap = new HashMap();
 }
 Map<String,Object> map = (Map) JSON.parse(json);

 for(String key:map.keySet())
 {
  Object object=map.get(key);
  if(isEntity(object)){
  String jsonString = JSON.toJSONString(object);
  JsonFormatterAddPrefix(jsonString,prefix+key+".",newmap);
  
  }else{
  newmap.put(prefix+key, object);
  }
  
 }
 return JSON.toJSONString(newmap); 
 }
 /**
 * 判斷某對象是不是實體
 * @param object
 * @return
 */
 private static boolean isEntity(Object object)
 {
 if(object instanceof String )
 {
  return false;
 }
 if(object instanceof Integer )
 {
  return false;
 }
 if(object instanceof Long )
 {
  return false;
 }
 if(object instanceof java.math.BigDecimal )
 {
  return false;
 }
 if(object instanceof Date )
 {
  return false;
 }
 if(object instanceof java.util.Collection )
 {
  return false;
 }
 return true;
 
 }
}

二、Jackson

1.同樣也需要導入 jar 包,Jackson 導入的 jar 包有三個

如何構建一個JSON字符串

具體使用也通過一個小例子說明:

package com.software.jackson;

import java.util.Arrays;
import java.util.List;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;

public class Customer {

 private int id;

 private String name;

 public Customer(int id, String name) {
  super();
  this.id = id;
  this.name = name;
 }

 public int getId() {
  return id;
 }

 public void setId(int id) {
  this.id = id;
 }

 public String getName() {
  return name;
 }

 public void setName(String name) {
  this.name = name;
 }
 
 public String getCity(){
  return "BeiJing";
 }
 
 @JsonIgnore
 public String getSchool(){
  return "School";
 }
 
 public static void main(String[] args) throws JsonProcessingException {
  //創建ObjectMapper對象
  ObjectMapper mapper = new ObjectMapper();
  
  Customer customer = new Customer(1, "Tom");
  List<Customer> lists = Arrays.asList(customer, new Customer(2, "Bob"));
  
  //調用 ObjectMapper 的 writeValueAsString(xxx) 方法,把一個對象或幾個傳入,轉為一個 JSON 字符串
  String jsonStr = mapper.writeValueAsString(lists);
  System.out.println(jsonStr);
  
 }

}

定義了一個 Customer 類,38 行和 43 行定義了兩個額外的 get 方法并直接賦值,main 方法中創建 ObjectMapper 的對象,調用其 writeValueAsString() 方法,傳入單個對象或對象的集合,便會返回對應的 JSON 字符串,打印結果為:[{"id":1,"name":"Tom","city":"BeiJing"},{"id":2,"name":"Bob","city":"BeiJing"}],大家可能會發現,我們 43 行定義的 getSchool() 方法中的 School 沒有被打印出,這是因為我們在此方法上添加了 @JsonIgnore 注解,添加了此注解,在構造 JSON 字符串時便忽略此屬性,細想一下 ,此注解添加到 get 方法上,這也說明 Jackson 構造 JSON 字符串時基于 getter 方法的。

2.與之前一樣,我們想看一看 Jackson 有沒有禁止循環的引用,類似的代碼:

  @Test
 public void test2() throws JsonProcessingException {
  List<Customer> lists = new ArrayList<>();

  Customer customer = new Customer();
  customer.setId(1);
  customer.setCustName("Tom");
  customer.setAddress("BeiJing");

  lists.add(customer);
  lists.add(customer);
  
  ObjectMapper mapper = new ObjectMapper();
  String jsonStr = mapper.writeValueAsString(lists);
  System.out.println(jsonStr);
 }

來看一下輸出結果:[{"id":1,"custName":"Tom","address":"BeiJing"},{"id":1,"custName":"Tom","address":"BeiJing"}],結果顯而易見。

3.我們再來看一看如果像 Fastjson 中測試的 Department 和 Manager 雙向一對一映射的例子,Jackson 會表現的怎么樣:

  @Test
 public void test1() throws JsonProcessingException {
  Manager mgr = new Manager();
  mgr.setMgrId(1);
  mgr.setMgrName("Tom");
  
  Department dept = new Department();
  dept.setDeptId(2);
  dept.setDeptName("DEV");
  
  mgr.setDept(dept);
  dept.setManager(mgr);
  
  ObjectMapper mapper = new ObjectMapper();
  String jsonStr = mapper.writeValueAsString(dept);
  System.out.println(jsonStr);
 }

直接運行還是會出相同的異常 Caused by: java.lang.StackOverflowError,我們的思路與測試 Fastjson 一樣,為 Department 中的 Manager 引用添加 @JsonIgnore 注解,異常解決了,但打印結果是很滿意,結果為:{"deptId":2,"deptName":"DEV"} ,遠不如 Fastjson 的輸出結果。由此可以看出 Fastjson 功能之強大。

三、Google Gson

1.看看如何使用:jar 包呢只需要一個 gson-2.2.4.jar ,普通對象與集合轉為 JSON 沒有什么可說的,簡單演示一下將 List 集合轉為 JSON 字符串吧,直接 new 出 Gson 的對象,調用其 toJson() 方法傳入需要轉換的對象即可。

  @Test
 public void test2() {
  List<Customer> lists = new ArrayList<>();

  Customer customer = new Customer();
  customer.setId(1);
  customer.setCustName("Tom");
  customer.setAddress("BeiJing");

  lists.add(customer);

  Customer customer2 = new Customer();
  customer2.setId(1);
  customer2.setCustName("Bob");
  customer2.setAddress("ShangHai");

  lists.add(customer2);

  Gson gson = new Gson();
  String jsonStr = gson.toJson(lists);
  System.out.println(jsonStr);
 }

打印結果:[{"address":"BeiJing","custName":"Tom","id":1},{"address":"ShangHai","custName":"Bob","id":1}]

2. 那有沒有禁止循環引用呢?

  @Test
 public void test3() {
  List<Customer> lists = new ArrayList<>();

  Customer customer = new Customer();
  customer.setId(1);
  customer.setCustName("Tom");
  customer.setAddress("BeiJing");

  lists.add(customer);
  lists.add(customer);
  
  Gson gson = new Gson();
  String jsonStr = gson.toJson(lists);
  System.out.println(jsonStr);

 }

輸出結果:[{"id":1,"custName":"Tom","address":"BeiJing"},{"id":1,"custName":"Tom","address":"BeiJing"}],顯而易見是沒有的。

3.若有雙向一對一的關聯關系映射的話,Google Gson 也是會有死循環問題造成 java.lang.StackOverflowError 異常,但是 Gson 并沒有為我們提供一個注解,要解決此問題LZ提供一個解決方案的思路,Google Gson 使用的是 ExclusionStrategy 策略進行某個字段或某個域的序列化,可以通過此接口自定義一個 注解來解決此問題。但是建議大家如果涉及到雙向關聯關系的對象轉換為 JSON 的需求是,使用 Fastjson。

四、三種方式的簡單比較

LZ 從以下幾個方面來比較構造 JSON 字符串的三種方式:

1. jar 包方面:顯然是 Fastjson 和 Google Gson 勝出,Jackson 需要加入 3 個 jar 包。

2. 簡單對象或集合轉為 JSON:若是普通的簡單對象或集合進行轉換,可能 Jackson 和 Google Gson 要勝出一些了,起碼構造比較方便。

3. 涉及到雙向關聯關系的轉換:毫無疑問阿里巴巴的 Fastjson 將勝出。

建議大家在實際的開發中根據自己的需求合理選擇某一方式。

以上就是如何構建一個JSON字符串,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东辽县| 安福县| 公主岭市| 青神县| 巨野县| 新昌县| 陇南市| 雷州市| 正宁县| 临清市| 西昌市| 台东县| 禹城市| 天等县| 定边县| 玉田县| 神池县| 阜宁县| 竹溪县| 沈丘县| 德州市| 金乡县| 丽江市| 兴安县| 彭山县| 临武县| 盐城市| 方山县| 华坪县| 宁安市| 阿勒泰市| 大竹县| 滁州市| 青河县| 武汉市| 新闻| 武冈市| 谢通门县| 大连市| 乐至县| 于田县|