Gson-シリアル化からフィールドを除外する

デフォルトでは、GSONはシリアル化/逆シリアル化プロセスから一時フィールドと静的フィールドを除外します。次の例を見てみましょう。

名前の付いたJavaクラスファイルを作成します GsonTester C:\> GSON_WORKSPACEで。

File − GsonTester.java

import com.google.gson.Gson; 
import com.google.gson.GsonBuilder;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      GsonBuilder builder = new GsonBuilder();     
      Gson gson = builder.create();  
      
      Student student = new Student(); 
      student.setRollNo(1); 
      student.setName("Mahesh Kumar"); 
      student.setVerified(true); 
      student.setId(1); 
      student.className = "VI";  
      
      String jsonString = gson.toJson(student); 
      System.out.println(jsonString);    
   }      
} 

class Student { 
   private int rollNo; 
   private String name; 
   private boolean verified;  
   private transient int id; 
   public static String className;  
   
   public int getRollNo() {
      return rollNo; 
   }  
   
   public void setRollNo(int rollNo) { 
      this.rollNo = rollNo; 
   } 
   
   public String getName() { 
      return name; 
   } 
   
   public void setName(String name) { 
      this.name = name; 
   }  
   
   public void setVerified(boolean verified) { 
      this.verified = verified; 
   }  
   
   public boolean isVerified() { 
      return verified; 
   }  
   
   public int getId() { 
      return id; 
   } 
   
   public void setId(int id) { 
      this.id = id; 
   } 
}

結果を確認する

を使用してクラスをコンパイルします javac 次のようにコンパイラ-

C:\GSON_WORKSPACE>javac GsonTester.java

今実行します GsonTester 結果を見るために-

C:\GSON_WORKSPACE>java GsonTester

出力を確認します

{"rollNo":1,"name":"Mahesh Kumar","verified":true}

excludeFieldsWithModifiersの使用

GsonBuilderは、シリアル化/逆シリアル化プロセスからexcludeFieldsWithModifiers()メソッドを使用して、特定の修飾子を持つフィールドを除外するための制御を提供します。次の例を参照してください。

C:\> GSON_WORKSPACEにGsonTesterという名前のJavaクラスファイルを作成します。

File − GsonTester.java

import java.lang.reflect.Modifier; 

import com.google.gson.Gson; 
import com.google.gson.GsonBuilder;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      GsonBuilder builder = new GsonBuilder(); 
      builder.excludeFieldsWithModifiers(Modifier.TRANSIENT);    
      Gson gson = builder.create();  
      
      Student student = new Student(); 
      student.setRollNo(1); 
      student.setName("Mahesh Kumar"); 
      student.setVerified(true); 
      student.setId(1); 
      student.className = "VI";  
      
      String jsonString = gson.toJson(student); 
      System.out.println(jsonString);    
   }      
} 

class Student { 
   private int rollNo; 
   private String name;
   private boolean verified;  
   private transient int id; 
   public static String className;  
   
   public int getRollNo() { 
      return rollNo; 
   }  
   
   public void setRollNo(int rollNo) { 
      this.rollNo = rollNo; 
   }  
   
   public String getName() { 
      return name; 
   }  
   
   public void setName(String name) { 
      this.name = name; 
   }  
   
   public void setVerified(boolean verified) { 
      this.verified = verified; 
   }  
   
   public boolean isVerified() { 
      return verified; 
   } 
   
   public int getId() { 
      return id; 
   } 
   
   public void setId(int id) { 
      this.id = id; 
   } 
}

結果を確認する

を使用してクラスをコンパイルします javac 次のようにコンパイラ-

C:\GSON_WORKSPACE>javac GsonTester.java

今実行します GsonTester 結果を見るために-

C:\GSON_WORKSPACE>java GsonTester

出力を確認します

{"rollNo":1,"name":"Mahesh Kumar","verified":true,"className":"VI"}

@Exposeアノテーションの使用

Gsonは提供します @Exposeスコープに基づいてクラスのJsonシリアル化/逆シリアル化を制御するためのアノテーション。変数を持つ次のクラスを考えてみましょう。@Exposeサポート。このクラスでは、name そして rollno変数はシリアル化のために公開されます。次に、GsonBuilder.excludeFieldsWithoutExposeAnnotation()公開された変数のみがシリアル化/逆シリアル化されることを示すメソッド。次の例を参照してください。

名前の付いたJavaクラスファイルを作成します GsonTester C:\> GSON_WORKSPACEで。

File − GsonTester.java

import com.google.gson.Gson; 
import com.google.gson.GsonBuilder; 
import com.google.gson.annotations.Expose;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      GsonBuilder builder = new GsonBuilder();     
      builder.excludeFieldsWithoutExposeAnnotation(); 
      Gson gson = builder.create();  
      
      Student student = new Student(); 
      student.setRollNo(1); 
      student.setName("Mahesh Kumar"); 
      student.setVerified(true); 
      student.setId(1); 
      student.className = "VI"; 
      
      String jsonString = gson.toJson(student); 
      System.out.println(jsonString);    
   }      
} 
class Student { 
   @Expose 
   private int rollNo; 
   
   @Expose 
   private String name; 
   private boolean verified;  
   private int id; 
   public static String className;  
   
   public int getRollNo() { 
      return rollNo; 
   }  
   public void setRollNo(int rollNo) { 
      this.rollNo = rollNo; 
   }  
   public String getName() { 
      return name; 
   }  
   public void setName(String name) { 
      this.name = name; 
   }  
   public void setVerified(boolean verified) { 
      this.verified = verified; 
   }  
   public boolean isVerified() { 
      return verified; 
   }  
   public int getId() { 
      return id; 
   }  
   public void setId(int id) { 
      this.id = id; 
   } 
}

結果を確認する

を使用してクラスをコンパイルします javac 次のようにコンパイラ-

C:\GSON_WORKSPACE>javac GsonTester.java

今実行します GsonTester 結果を見るために-

C:\GSON_WORKSPACE>java GsonTester

出力を確認します

{"rollNo":1,"name":"Mahesh Kumar"}