Gson的入門使用


Java對象和Json之間的互轉,一般用的比較多的兩個類庫是Jackson和Gson,下面記錄一下Gson的學習使用。

基礎概念:
 Serialization:序列化,使Java對象到Json字符串的過程。
 Deserialization:反序列化,字符串轉換成Java對象
 
使用Maven管理Gson,pom.xml導入gson的依賴
  <dependency>
     <groupId>com.google.code.gson</groupId>
     <artifactId>gson</artifactId>
     <version>2.3.1</version>
  </dependency>
 
Gson的兩個基礎方法
toJson();
fromJson();
 
Gson的創建方式一:直接new Gson對象
// 使用new方法
Gson gson = new Gson();

// toJson 將bean對象轉換為json字符串
String jsonStr = gson.toJson(user, User.class);

// fromJson 將json字符串轉為bean對象
Student user= gson.fromJson(jsonStr, User.class);

// **序列化List**
String jsonStr2 = gson.toJson(list);

// **反序列化成List時需要使用到TypeToken getType()**
List<User> retList = gson.fromJson(jsonStr2,new TypeToken<List<User>>(){}.getType());

 

Gson的創建方式二:使用GsonBuilder
使用new Gson(),此時會創建一個帶有默認配置選項的Gson實例,如果不想使用默認配置,那么就可以使用GsonBuilder。
//serializeNulls()是GsonBuilder提供的一種配置,當字段值為空或null時,依然對該字段進行轉換
Gson gson = new GsonBuilder().serializeNulls().create(); 
使用GsonBuilder創建Gson實例的步驟:
首先創建GsonBuilder,然后調用GsonBuilder提供的各種配置方法進行配置,
最后調用GsonBuilder的create方法,將基於當前的配置創建一個Gson實例。
 
GsonBuilder的一些配置
 Gson gson = new GsonBuilder()
         .excludeFieldsWithoutExposeAnnotation() //不對沒有用@Expose注解的屬性進行操作
         .enableComplexMapKeySerialization() //當Map的key為復雜對象時,需要開啟該方法
         .serializeNulls() //當字段值為空或null時,依然對該字段進行轉換
         .setDateFormat("yyyy-MM-dd HH:mm:ss:SSS") //時間轉化為特定格式
         .setPrettyPrinting() //對結果進行格式化,增加換行
         .disableHtmlEscaping() //防止特殊字符出現亂碼
         .registerTypeAdapter(User.class,new UserAdapter()) //為某特定對象設置固定的序列或反序列方式,自定義Adapter需實現JsonSerializer或者JsonDeserializer接口
         .create();

例如:Gosn對復雜Map的處理時需要用到其中的 enableComplexMapKeySerialization() 配置:

Gson gson = new GsonBuilder().enableComplexMapKeySerialization().create(); //開啟復雜處理Map方法
Map<List<User>, String> map = new HashMap<List<User>, String>();
// TODO 向map中添加數據
String jsonStr = gson.toJson(map);  //toJson
Map<List<User>, String> resultMap = gson.fromJson(jsonStr,new TypeToken<Map<List<User>, String>>() {}.getType()); //fromJson

注意:如果Map的key為String,則可以不使用GsonBuilder的enableComplexMapKeySerialization()方法,或者直接new Gson();

 

Gson的注解:
@Expose注解
public class User {
  @Expose
  private String firstName;

  @Expose(serialize = false)
  private String lastName;

  @Expose(deserialize = false)
  private String emailAddress;

  private String password;
}
@Expose中serialize和deserialize屬性是可選的,默認兩個都為true。
如果serialize為true,調用toJson時會序列化該屬性,
如果deserialize為true,調用fromJson生成Java對象時不會進行反序列化。
注意:如果采用new Gson()方式創建Gson,@Expose沒有任何效果。需要使用 gsonBuilder.excludeFieldsWithoutExposeAnnotation()方法。
 
@SerializedName注解    能指定該字段在序列化成json時的名稱
  @SerializedName("w")
  private int width;

 

實際開發中我們會遇到比較復雜的Json,比如json中嵌套json數組,這個時候,就需要我們自定義序列化或反序列化方法了。
待續未完....
 
參考:
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM