Gson - Felder von der Serialisierung ausschließen
Standardmäßig schließt GSON transiente und statische Felder vom Serialisierungs- / Deserialisierungsprozess aus. Schauen wir uns das folgende Beispiel an.
Beispiel
Erstellen Sie eine Java-Klassendatei mit dem Namen GsonTester in 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;
}
}
Überprüfen Sie das Ergebnis
Kompilieren Sie die Klassen mit javac Compiler wie folgt -
C:\GSON_WORKSPACE>javac GsonTester.java
Führen Sie nun die aus GsonTester um das Ergebnis zu sehen -
C:\GSON_WORKSPACE>java GsonTester
Überprüfen Sie die Ausgabe
{"rollNo":1,"name":"Mahesh Kumar","verified":true}
Verwenden von excludeFieldsWithModifiers
GsonBuilder bietet die Kontrolle über das Ausschließen von Feldern mit einem bestimmten Modifikator mithilfe der Methode excludeFieldsWithModifiers () aus dem Serialisierungs- / Deserialisierungsprozess. Siehe folgendes Beispiel.
Beispiel
Erstellen Sie eine Java-Klassendatei mit dem Namen GsonTester in C: \> GSON_WORKSPACE.
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;
}
}
Überprüfen Sie das Ergebnis
Kompilieren Sie die Klassen mit javac Compiler wie folgt -
C:\GSON_WORKSPACE>javac GsonTester.java
Führen Sie nun die aus GsonTester um das Ergebnis zu sehen -
C:\GSON_WORKSPACE>java GsonTester
Überprüfen Sie die Ausgabe
{"rollNo":1,"name":"Mahesh Kumar","verified":true,"className":"VI"}
Verwenden von @Expose Annotation
Gson bietet @ExposeAnmerkung zur Steuerung der Json-Serialisierung / Deserialisierung einer Klasse basierend auf ihrem Umfang. Betrachten Sie die folgende Klasse mit einer Variablen mit@ExposeUnterstützung. In dieser Klasse,name und rollnoVariablen sollen zur Serialisierung verfügbar gemacht werden. Dann haben wir das benutztGsonBuilder.excludeFieldsWithoutExposeAnnotation()Methode, um anzuzeigen, dass nur exponierte Variablen serialisiert / deserialisiert werden sollen. Siehe folgendes Beispiel.
Beispiel
Erstellen Sie eine Java-Klassendatei mit dem Namen GsonTester in 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;
}
}
Überprüfen Sie das Ergebnis
Kompilieren Sie die Klassen mit javac Compiler wie folgt -
C:\GSON_WORKSPACE>javac GsonTester.java
Führen Sie nun die aus GsonTester um das Ergebnis zu sehen -
C:\GSON_WORKSPACE>java GsonTester
Überprüfen Sie die Ausgabe
{"rollNo":1,"name":"Mahesh Kumar"}