Gson - त्वरित गाइड

Google Gson जावा वस्तुओं को JSON और इसके विपरीत में अनुक्रमित करने के लिए एक सरल जावा-आधारित पुस्तकालय है। यह Google द्वारा विकसित एक ओपन-सोर्स लाइब्रेरी है।

निम्नलिखित बिंदुओं पर प्रकाश डाला गया है कि आपको इस पुस्तकालय का उपयोग क्यों करना चाहिए -

  • Standardized - Gson एक मानकीकृत पुस्तकालय है जिसे Google द्वारा प्रबंधित किया जाता है।

  • Efficient - यह जावा मानक पुस्तकालय के लिए एक विश्वसनीय, तेज और कुशल विस्तार है।

  • Optimized - पुस्तकालय अत्यधिक अनुकूलित है।

  • Support Generics - यह जेनरिक के लिए व्यापक समर्थन प्रदान करता है।

  • Supports complex inner classes - यह गहरी विरासत पदानुक्रम के साथ जटिल वस्तुओं का समर्थन करता है।

ग्सन की विशेषताएँ

यहाँ Gson की कुछ प्रमुख विशेषताओं की सूची दी गई है -

  • Easy to use - Gson एपीआई आमतौर पर उपयोग किए जाने वाले मामलों को सरल बनाने के लिए एक उच्च-स्तरीय मुखौटा प्रदान करता है।

  • No need to create mapping - Gson API अधिकांश ऑब्जेक्ट्स को क्रमबद्ध करने के लिए डिफ़ॉल्ट मैपिंग प्रदान करता है।

  • Performance- Gson काफी तेज है और लो मेमोरी फुटप्रिंट का है। यह बड़े ऑब्जेक्ट ग्राफ या सिस्टम के लिए उपयुक्त है।

  • Clean JSON - Gson एक साफ और कॉम्पैक्ट JSON परिणाम बनाता है जिसे पढ़ना आसान है।

  • No Dependency - Gson लाइब्रेरी को JDK के अलावा किसी अन्य लाइब्रेरी की आवश्यकता नहीं है।

  • Open Source- Gson पुस्तकालय खुला स्रोत है; यह स्वतंत्र रूप से उपलब्ध है।

प्रसंस्करण JSON के तीन तरीके

GSON JSON को संसाधित करने के लिए तीन वैकल्पिक तरीके प्रदान करता है -

स्ट्रीमिंग एपीआई

यह JSON सामग्री को असतत घटनाओं के रूप में पढ़ता और लिखता है। JsonReader तथा JsonWriter डेटा को टोकन के रूप में पढ़ें / लिखें, जैसा कि संदर्भित है JsonToken

JSON को संसाधित करने के लिए तीन दृष्टिकोणों में से यह सबसे शक्तिशाली दृष्टिकोण है। यह सबसे कम ओवरहेड है और यह पढ़ने / लिखने के कार्यों में काफी तेज है। यह XML के लिए Stax parser के अनुरूप है।

ट्री मॉडल

यह JSON दस्तावेज़ का इन-मेमोरी ट्री प्रतिनिधित्व तैयार करता है। यह JsonObject नोड्स का एक पेड़ बनाता है। यह एक लचीला दृष्टिकोण है और XML के लिए DOM पार्सर के अनुरूप है।

अनिवार्य तथ्य

यह प्रॉपर्टी एक्सेसर का उपयोग करके JSON को POJO (प्लेन ओल्ड जावा ऑब्जेक्ट) से और से कनवर्ट करता है। GSON डेटा टाइप एडेप्टर का उपयोग करके JSON पढ़ता / लिखता है। यह XML के लिए JAXB पार्सर के अनुरूप है।

स्थानीय पर्यावरण सेटअप

यदि आप अभी भी जावा प्रोग्रामिंग भाषा के लिए एक स्थानीय वातावरण सेट करना चाहते हैं, तो यह अनुभाग आपको अपनी मशीन पर जावा को डाउनलोड और सेट करने के तरीके के बारे में मार्गदर्शन करेगा। पर्यावरण को स्थापित करने के लिए, कृपया नीचे दिए गए चरणों का पालन करें।

जावा एसई डाउनलोड जावा से लिंक से स्वतंत्र रूप से उपलब्ध है । इसलिए आप अपने ऑपरेटिंग सिस्टम के आधार पर एक संस्करण डाउनलोड करते हैं।

जावा डाउनलोड करने और चलाने के लिए निर्देशों का पालन करें .exeअपनी मशीन पर जावा स्थापित करने के लिए। एक बार जब आप अपनी मशीन पर जावा स्थापित कर लेते हैं, तो आपको उनकी सही स्थापना निर्देशिकाओं को इंगित करने के लिए पर्यावरण चर सेट करना होगा।

Windows 2000 / XP में पथ सेट करना

मान लें कि आपने c: \ Program Files \ java \ jdk निर्देशिका में Java स्थापित किया है -

  • 'मेरा कंप्यूटर' पर राइट-क्लिक करें और 'गुण' चुनें।

  • 'उन्नत' टैब के अंतर्गत 'पर्यावरण चर' बटन पर क्लिक करें।

  • इसके बाद, 'Path' वेरिएबल को बदल दें ताकि इसमें Java एक्जीक्यूटेबल का भी पथ शामिल हो। उदाहरण के लिए, यदि पथ वर्तमान में 'C: \ WINDOWS \ SYSTEM32' पर सेट है, तो 'C: \ WINDOWS \ SYSTEM32; c: \ Program Files \ java \ jdk \ bin' पढ़ने के लिए अपना पथ परिवर्तित करें।

Windows 95/98 / ME में पथ सेट करना

मान लें कि आपने c: \ Program Files \ java \ jdk निर्देशिका में Java स्थापित किया है -

  • 'C: \ autoexec.bat' फ़ाइल संपादित करें और अंत में निम्नलिखित पंक्ति जोड़ें: 'PATH =% PATH%; C: \ Program Files \ java \ jdk \ bin'

लिनक्स, यूनिक्स, सोलारिस, फ्रीबीएसडी के लिए पथ की स्थापना

पर्यावरण चर PATHयह इंगित करने के लिए सेट होना चाहिए कि जावा बायनेरिज़ को कहाँ स्थापित किया गया है। यदि आपको ऐसा करने में परेशानी होती है, तो अपने शेल दस्तावेज़ देखें।

उदाहरण के लिए, यदि आप अपने शेल के रूप में बैश का उपयोग करते हैं, तो आप अपने '.Bashrc: PATH = / path / to / java: $ PATH' के अंत में निम्न पंक्ति जोड़ेंगे।

लोकप्रिय जावा संपादक

अपने जावा प्रोग्राम लिखने के लिए, आपको एक टेक्स्ट एडिटर की आवश्यकता होगी। बाजार में काफी कुछ परिष्कृत IDE उपलब्ध हैं। लेकिन अभी के लिए, आप निम्नलिखित में से एक पर विचार कर सकते हैं -

  • Notepad - विंडोज पर, आप किसी भी साधारण टेक्स्ट एडिटर जैसे नोटपैड (इस ट्यूटोरियल के लिए अनुशंसित) या टेक्स्टपैड का उपयोग कर सकते हैं।

  • Netbeans - यह एक जावा आईडीई है जो ओपन-सोर्स और फ्री है जिसे डाउनलोड किया जा सकता है https://netbeans.org/index.html।

  • Eclipse - यह एक जावा आईडीई भी है जिसे एक्लिप्स ओपन-सोर्स समुदाय द्वारा विकसित किया गया है और इससे डाउनलोड किया जा सकता है https://www.eclipse.org/।

Gson संग्रह डाउनलोड करें

से Gson jar फ़ाइल का नवीनतम संस्करण डाउनलोड करें gson-2.3.1.jar। इस ट्यूटोरियल को लिखने के समय, हमने gson-2.3.1.jar डाउनलोड किया और इसे C: \> gson फ़ोल्डर में कॉपी किया।

ओएस संग्रह का नाम
खिड़कियाँ gson-2.3.1.jar
लिनक्स gson-2.3.1.jar
मैक gson-2.3.1.jar

Gson पर्यावरण सेट करें

ठीक GSON_HOME बेस चर स्थान पर इंगित करने के लिए पर्यावरण चर जहां आपकी मशीन पर Gson जार संग्रहीत है।

ओएस उत्पादन
खिड़कियाँ पर्यावरण चर GSON_HOME को C: \ gson पर सेट करें
लिनक्स GSON_HOME = / usr / स्थानीय / gson निर्यात करें
मैक GSON_HOME = / लाइब्रेरी / gson को निर्यात करें

CLASSPATH चर सेट करें

ठीक CLASSPATH पर्यावरण चर Gson जार स्थान को इंगित करने के लिए।

ओएस उत्पादन
खिड़कियाँ वातावरण चर CLASSPATH को% CLASSPATH%;% GSON_HOME% \ gson-2.3.1.jar; पर सेट करें।
लिनक्स निर्यात CLASSPATH = $ CLASSPATH: $ GSON_HOME / gson-2.3.1.jar:।
मैक निर्यात CLASSPATH = $ CLASSPATH: $ GSON_HOME / gson-2.3.1.jar:।

Google Gson लाइब्रेरी के विवरण में जाने से पहले, आइए एक एप्लिकेशन देखें। इस उदाहरण में, हमने एक बनाया हैStudentकक्षा। हम छात्र के विवरण के साथ एक JSON स्ट्रिंग बनाएंगे और उसे इसके लिए आवश्यक करेंगेstudent ऑब्जेक्ट और फिर इसे JSON स्ट्रिंग में क्रमबद्ध करें।

उदाहरण

C: \> GSON_WORKSPACE में GsonTester नाम से जावा क्लास फ़ाइल बनाएँ।

File − GsonTester.java

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

public class GsonTester { 
   public static void main(String[] args) { 
      String jsonString = "{\"name\":\"Mahesh\", \"age\":21}"; 
      
      GsonBuilder builder = new GsonBuilder(); 
      builder.setPrettyPrinting(); 
      
      Gson gson = builder.create(); 
      Student student = gson.fromJson(jsonString, Student.class); 
      System.out.println(student);    
      
      jsonString = gson.toJson(student); 
      System.out.println(jsonString);  
   } 
} 

class Student { 
   private String name; 
   private int age; 
   public Student(){} 
   
   public String getName() { 
      return name; 
   }
   
   public void setName(String name) { 
      this.name = name; 
   } 
   
   public int getAge() { 
      return age; 
   }
   
   public void setAge(int age) { 
      this.age = age; 
   }
   
   public String toString() { 
      return "Student [ name: "+name+", age: "+ age+ " ]"; 
   }  
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब परिणाम देखने के लिए GsonTester चलाएं -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

Student [ name: Mahesh, age: 21 ] 
{ 
   "name" : "Mahesh", 
   "age" : 21 
}

याद करने के लिए कदम

निम्नलिखित महत्वपूर्ण कदम यहाँ पर विचार किया जाना है।

चरण 1 - GsonBuilder का उपयोग करके Gson ऑब्जेक्ट बनाएँ

Gson ऑब्जेक्ट बनाएँ। यह एक पुन: प्रयोज्य वस्तु है।

GsonBuilder builder = new GsonBuilder(); 
builder.setPrettyPrinting(); 
Gson gson = builder.create();

चरण 2 - ऑब्जेक्ट के लिए JSON का वर्णन करें

JSON से ऑब्जेक्ट प्राप्त करने के लिएJson () विधि से उपयोग करें। Json string / Json string के स्रोत और ऑब्जेक्ट प्रकार को पैरामीटर के रूप में पास करें।

//Object to JSON Conversion 
Student student = gson.fromJson(jsonString, Student.class);

चरण 3 - JSON के लिए ऑब्जेक्ट को सीरियल करें

किसी वस्तु के JSON स्ट्रिंग प्रतिनिधित्व को प्राप्त करने के लिए toJson () विधि का उपयोग करें।

//Object to JSON Conversion   
jsonString = gson.toJson(student);

Gson Google Gson लाइब्रेरी का मुख्य अभिनेता वर्ग है। यह जावा वस्तुओं को जेएसएन कंस्ट्रक्शन और इसके विपरीत मिलान करने के लिए कार्यात्मकता प्रदान करता है। Gson का निर्माण पहले GsonBuilder का उपयोग करके किया गया है और फिर, JSON (ऑब्जेक्ट) याJson (स्ट्रिंग, क्लास) विधियों का उपयोग JSON कंस्ट्रक्शन को पढ़ने / लिखने के लिए किया जाता है।

वर्ग घोषणा

निम्नलिखित के लिए घोषणा है com.google.gson.Gson वर्ग -

public final class Gson 
   extends Object

कंस्ट्रक्टर्स

अनु क्रमांक कंस्ट्रक्टर और विवरण
1

Gson()

डिफ़ॉल्ट कॉन्फ़िगरेशन के साथ एक Gson ऑब्जेक्ट बनाता है।

कक्षा के तरीके

अनु क्रमांक विधि और विवरण
1

<T> T fromJson(JsonElement json, Class<T> classOfT)

यह विधि निर्दिष्ट प्रकार के ऑब्जेक्ट में निर्दिष्ट पार्स ट्री से पढ़े गए Json को deserializes।

2

<T> T fromJson(JsonElement json, Type typeOfT)

यह विधि निर्दिष्ट प्रकार के ऑब्जेक्ट में निर्दिष्ट पार्स ट्री से पढ़े गए Json को deserializes।

3

<T> T fromJson(JsonReader reader, Type typeOfT)

पाठक से अगले JSON मान पढ़ता है और इसे typeOfT के ऑब्जेक्ट में परिवर्तित करता है।

4

<T> T fromJson(Reader json, Class<T> classOfT)

यह विधि निर्दिष्ट रीडर से पढ़ी गई Json को निर्दिष्ट वर्ग के ऑब्जेक्ट में दर्शाती है।

5

<T> T fromJson(Reader json, Type typeOfT)

यह विधि निर्दिष्ट रीडर से पढ़ी गई Json को निर्दिष्ट प्रकार के ऑब्जेक्ट में दर्शाती है।

6

<T> T fromJson(String json, Class<T> classOfT)

यह विधि निर्दिष्ट JSON को निर्दिष्ट वर्ग की एक वस्तु में विभाजित करती है।

7

<T> T fromJson(String json, Type typeOfT)

यह विधि निर्दिष्ट प्रकार के ऑब्जेक्ट में निर्दिष्ट Json को डिसेर्बलाइज करती है।

8

<T> TypeAdapter<T> getAdapter(Class<T> type)

प्रकार के लिए प्रकार एडाप्टर लौटाता है।

9

<T> TypeAdapter<T> getAdapter(TypeToken<T> type)

प्रकार के लिए प्रकार एडाप्टर लौटाता है।

10

<T> TypeAdapter<T> getDelegateAdapter(TypeAdapterFactory skipPast, TypeToken<T> type)

इस पद्धति का उपयोग निर्दिष्ट प्रकार के लिए एक वैकल्पिक प्रकार के एडाप्टर को प्राप्त करने के लिए किया जाता है।

1 1

String toJson(JsonElement jsonElement)

JSONElements के एक पेड़ को इसके बराबर JSON प्रतिनिधित्व में परिवर्तित करता है।

12

void toJson(JsonElement jsonElement, Appendable writer)

JsonElements के एक पेड़ के लिए बराबर JSON लिखते हैं।

13

void toJson(JsonElement jsonElement, JsonWriter writer)

लेखक को jsonElement के लिए JSON लिखते हैं।

14

String toJson(Object src)

यह विधि निर्दिष्ट वस्तु को उसके समकक्ष जोंस प्रतिनिधित्व में क्रमबद्ध करती है।

15

void toJson(Object src, Appendable writer)

यह विधि निर्दिष्ट वस्तु को उसके समकक्ष जोंस प्रतिनिधित्व में क्रमबद्ध करती है।

16

String toJson(Object src, Type typeOfSrc)

यह विधि निर्दिष्ट वस्तु को क्रमबद्ध करती है, जिसमें सामान्य प्रकार के लोग भी शामिल हैं, इसके समतुल्य जोंस प्रतिनिधित्व में।

17

void toJson(Object src, Type typeOfSrc, Appendable writer)

यह विधि निर्दिष्ट वस्तु को क्रमबद्ध करती है, जिसमें सामान्य प्रकार के लोग भी शामिल हैं, इसके समतुल्य जोंस प्रतिनिधित्व में।

18

void toJson(Object src, Type typeOfSrc, JsonWriter writer)

लेखक के प्रकार के src के JSON प्रतिनिधित्व को लिखता है।

19

JsonElement toJsonTree(Object src)

यह विधि निर्दिष्ट वस्तु को अपने समकक्ष प्रतिनिधित्व में JsonElements के पेड़ के रूप में क्रमबद्ध करती है।

20

JsonElement toJsonTree(Object src, Type typeOfSrc)

यह विधि जेनेसिस के पेड़ के रूप में इसके समकक्ष प्रतिनिधित्व में, सामान्य प्रकार के लोगों सहित निर्दिष्ट ऑब्जेक्ट को क्रमबद्ध करती है।

21

String toString()

तरीके विरासत में मिले

इस वर्ग को निम्न वर्ग से विधियाँ प्राप्त होती हैं -

  • java.lang.Object

उदाहरण

अपनी पसंद के किसी भी संपादक का उपयोग करके निम्नलिखित जावा प्रोग्राम बनाएं, और उस पर सहेजें, कहें: 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) { 
      String jsonString = "{\"name\":\"Mahesh\", \"age\":21}"; 
      
      GsonBuilder builder = new GsonBuilder(); 
      builder.setPrettyPrinting(); 
      
      Gson gson = builder.create(); 
      Student student = gson.fromJson(jsonString, Student.class); 
      System.out.println(student);    
      
      jsonString = gson.toJson(student); 
      System.out.println(jsonString);  
   } 
}  

class Student { 
   private String name; 
   private int age; 
   public Student(){} 
   
   public String getName() { 
      return name; 
   } 
   public void setName(String name) { 
      this.name = name; 
   } 
   public int getAge() { 
      return age;
   } 
   public void setAge(int age) { 
      this.age = age; 
   } 
   public String toString() { 
      return "Student [ name: "+name+", age: "+ age+ " ]"; 
   }  
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब परिणाम देखने के लिए GsonTester चलाएं -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें

Student [ name: Mahesh, age: 21 ] 
{ 
   "name" : "Mahesh", 
   "age" : 21 
}

आइए एक जावा ऑब्जेक्ट को एक Json फ़ाइल में क्रमबद्ध करें और फिर ऑब्जेक्ट को वापस लाने के लिए उस Json फ़ाइल को पढ़ें। इस उदाहरण में, हमने एक बनाया हैStudentकक्षा। हम पैदा करेंगेstudent.json फ़ाइल जिसमें एक होगा json का प्रतिनिधित्व Student वस्तु।

उदाहरण

नाम से एक जावा वर्ग फ़ाइल बनाएँ GsonTester में C:\>GSON_WORKSPACE

फ़ाइल - GsonTester.java

import java.io.BufferedReader; 
import java.io.FileNotFoundException; 
import java.io.FileReader; 
import java.io.FileWriter; 
import java.io.IOException;  

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

public class GsonTester { 
   public static void main(String args[]) { 
   
      GsonTester tester = new GsonTester(); 
      try { 
         Student student = new Student(); 
         student.setAge(10); 
         student.setName("Mahesh"); 
         tester.writeJSON(student);  
         Student student1 = tester.readJSON(); 
         System.out.println(student1); 
      } 
      catch(FileNotFoundException e) { 
         e.printStackTrace(); 
      } 
      catch(IOException e) { 
         e.printStackTrace();
      } 
   } 
   
   private void writeJSON(Student student) throws IOException { 
      GsonBuilder builder = new GsonBuilder(); 
      Gson gson = builder.create(); 
      FileWriter writer = new FileWriter("student.json");   
      writer.write(gson.toJson(student));   
      writer.close(); 
   }  
   
   private Student readJSON() throws FileNotFoundException { 
      GsonBuilder builder = new GsonBuilder(); 
      Gson gson = builder.create(); 
      BufferedReader bufferedReader = new BufferedReader(
         new FileReader("student.json"));   
      
      Student student = gson.fromJson(bufferedReader, Student.class); 
      return student; 
   } 
} 

class Student { 
   private String name; 
   private int age; 
   public Student(){} 
   
   public String getName() { 
      return name; 
   } 
   
   public void setName(String name) { 
      this.name = name; 
   } 
   
   public int getAge() { 
      return age; 
   } 
   
   public void setAge(int age) { 
      this.age = age; 
   } 
   
   public String toString() { 
      return "Student [ name: "+name+", age: "+ age+ " ]";
   }  
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब परिणाम देखने के लिए GsonTester चलाएं -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें

Student [ name: Mahesh, age: 10 ]

डेटा बाइंडिंग एपीआई का उपयोग प्रॉपर्टी एक्सेसर का उपयोग करके या एनोटेशन का उपयोग करके JSON को POJO (प्लेन ओल्ड जावा ऑब्जेक्ट) से कन्वर्ट करने के लिए किया जाता है। यह दो प्रकार की होती है।

  • Primitives Data Binding - जावा मैप्स, लिस्ट्स, स्ट्रिंग्स, नंबर, बुलियन, और NULL ऑब्जेक्ट्स से JSON को परिवर्तित करता है।

  • Objects Data Binding - JSON को किसी भी JAVA प्रकार से परिवर्तित करता है।

Gson दोनों प्रकार के डेटा बाइंडिंग के लिए JSON पढ़ता / लिखता है। डेटा बाइंडिंग XML के लिए JAXB पार्सर के अनुरूप है।

प्रिमिटिव डेटा बाइंडिंग

प्रिमिटिव्स डेटा बाइंडिंग JSON से JAVA कोर डेटा टाइप्स और इनबिल्ट कलेक्शन की मैपिंग को संदर्भित करता है। Gson विभिन्न इनबिल्ट एडेप्टर प्रदान करता है जिनका उपयोग आदिम डेटा प्रकारों को क्रमांकित / डिसेरलाइज़ करने के लिए किया जा सकता है।

उदाहरण

आइए देखते हैं आदिम डेटा बाइंडिंग क्रिया में। यहां हम JAVA के बुनियादी प्रकारों को सीधे JSON में मैप करेंगे और इसके विपरीत।

नाम से एक जावा वर्ग फ़ाइल बनाएँ GsonTester में C:\>Gson_WORKSPACE

File − GsonTester.java

import java.util.Arrays; 
import com.google.gson.Gson;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      Gson gson = new Gson();  
      String name = "Mahesh Kumar"; 
      long rollNo = 1; 
      boolean verified = false; 
      int[] marks = {100,90,85};  
      
      //Serialization 
      System.out.println("{"); 
      System.out.println("name: " + gson.toJson(name) +","); 
      System.out.println("rollNo: " + gson.toJson(rollNo) +","); 
      System.out.println("verified: " + gson.toJson(verified) +","); 
      System.out.println("marks:" + gson.toJson(marks)); 
      System.out.println("}");  
      
      //De-serialization 
      name = gson.fromJson("\"Mahesh Kumar\"", String.class); 
      rollNo = gson.fromJson("1", Long.class); 
      verified = gson.fromJson("false", Boolean.class); 
      marks = gson.fromJson("[100,90,85]", int[].class);  
      
      System.out.println("name: " + name); 
      System.out.println("rollNo: " + rollNo); 
      System.out.println("verified: " +verified); 
      System.out.println("marks:" + Arrays.toString(marks)); 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{ 
   name: "Mahesh Kumar", 
   rollNo: 1, 
   verified: false, 
   marks:[100,90,85] 
} 

name: Mahesh Kumar 
rollNo: 1 
verified: false 
marks:[100, 90, 85]

ऑब्जेक्ट डेटा बाइंडिंग JSON की किसी भी JAPA ऑब्जेक्ट की मैपिंग को संदर्भित करता है।

//Create a Gson instance 
Gson gson = new Gson();  

//map Student object to JSON content 
String jsonString = gson.toJson(student);   

//map JSON content to Student object 
Student student1 = gson.fromJson(jsonString, Student.class);

उदाहरण

आइए कार्रवाई में ऑब्जेक्ट डेटा बाइंडिंग देखें। यहाँ हम JSON से सीधे JSON पर मैप करेंगे और इसके विपरीत।

नाम से एक जावा वर्ग फ़ाइल बनाएँ GsonTester C: \> GSON_WORKSPACE में।

फ़ाइल - GsonTester.java

import com.google.gson.Gson;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      Gson gson = new Gson(); 
      Student student = new Student(); 
      student.setAge(10); 
      student.setName("Mahesh"); 
      
      String jsonString = gson.toJson(student);          
      System.out.println(jsonString); 
      
      Student student1 = gson.fromJson(jsonString, Student.class); 
      System.out.println(student1); 
   }   
} 

class Student { 
   private String name; 
   private int age; 
   public Student(){} 
   
   public String getName() { 
      return name; 
   } 
   
   public void setName(String name) { 
      this.name = name; 
   } 
   
   public int getAge() { 
      return age; 
   } 
   
   public void setAge(int age) { 
      this.age = age; 
   } 
   
   public String toString() { 
      return "Student [ name: "+name+", age: "+ age+ " ]"; 
   }  
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{"name":"Mahesh","age":10} 
Student [ name: Mahesh, age: 10 ]

ट्री मॉडल JSON दस्तावेज़ का इन-मेमोरी ट्री प्रतिनिधित्व तैयार करता है। यह JsonObject नोड्स का एक पेड़ बनाता है। यह एक लचीला दृष्टिकोण है और XML के लिए DOM पार्सर के अनुरूप है।

JSON से ट्री बनाएं

JSONParser JSON पढ़ने के बाद पेड़ की जड़ नोड को एक संकेतक प्रदान करता है। रूट नोड का उपयोग पूर्ण पेड़ को पार करने के लिए किया जा सकता है। किसी दिए गए JSON स्ट्रिंग के रूट नोड प्राप्त करने के लिए निम्न कोड स्निपेट पर विचार करें।

//Create an JsonParser instance 
JsonParser parser = new JsonParser(); 

String jsonString = 
"{\"name\":\"Mahesh Kumar\", \"age\":21,\"verified\":false,\"marks\": [100,90,85]}"; 

//create tree from JSON 
JsonElement rootNode = parser.parse(jsonString);

ट्रेवर्सिंग ट्री मॉडल

पेड़ को ट्रेस करते समय रूट नोड के सापेक्ष पथ का उपयोग करके प्रत्येक नोड प्राप्त करें और डेटा को संसाधित करें। निम्न कोड स्निपेट दिखाता है कि आप किसी पेड़ को कैसे पार कर सकते हैं।

JsonObject details = rootNode.getAsJsonObject(); 

JsonElement nameNode = details.get("name"); 
System.out.println("Name: " +nameNode.getAsString()); 

JsonElement ageNode = details.get("age"); 
System.out.println("Age: " + ageNode.getAsInt());

उदाहरण

नाम से एक जावा वर्ग फ़ाइल बनाएँ GsonTester C: \> GSON_WORKSPACE में।

File − GsonTester.java

import com.google.gson.JsonArray; 
import com.google.gson.JsonElement; 
import com.google.gson.JsonObject; 
import com.google.gson.JsonParser;
import com.google.gson.JsonPrimitive;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      String jsonString = 
         "{\"name\":\"Mahesh Kumar\", \"age\":21,\"verified\":false,\"marks\": [100,90,85]}";
      JsonParser parser = new JsonParser();  
      JsonElement rootNode = parser.parse(jsonString);  
      
      if (rootNode.isJsonObject()) { 
         JsonObject details = rootNode.getAsJsonObject();  
         JsonElement nameNode = details.get("name"); 
         System.out.println("Name: " +nameNode.getAsString());  
         
         JsonElement ageNode = details.get("age"); 
         System.out.println("Age: " + ageNode.getAsInt());  
         
         JsonElement verifiedNode = details.get("verified"); 
         System.out.println("Verified: " + (verifiedNode.getAsBoolean() ? "Yes":"No"));  
         JsonArray marks = details.getAsJsonArray("marks"); 
         
         for (int i = 0; i < marks.size(); i++) { 
            JsonPrimitive value = marks.get(i).getAsJsonPrimitive(); 
            System.out.print(value.getAsInt() + " ");  
         } 
      } 
   }   
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

Name: Mahesh Kumar 
Age: 21 
Verified: No 
100 90 85

स्ट्रीमिंग एपीआई का उपयोग टोकन द्वारा JSON टोकन को पढ़ने के लिए किया जाता है। यह JSON सामग्री को असतत घटनाओं के रूप में पढ़ता और लिखता है।JsonReader तथा JsonWriter डेटा को टोकन के रूप में पढ़ें / लिखें, जैसा कि संदर्भित है JsonToken

JSON को संसाधित करने के लिए तीन दृष्टिकोणों में से यह सबसे शक्तिशाली दृष्टिकोण है। यह सबसे कम ओवरहेड है और यह पढ़ने / लिखने के कार्यों में काफी तेज है। यह XML के लिए Stax parser के अनुरूप है।

इस अध्याय में, हम JSON डेटा पढ़ने के लिए GSON स्ट्रीमिंग APIs के उपयोग का प्रदर्शन करेंगे। स्ट्रीमिंग एपीआई टोकन की अवधारणा के साथ काम करता है और जसन के हर विवरण को सावधानीपूर्वक संभाला जाना है।

//create JsonReader object and pass it the json source or json text. 
JsonReader reader = new JsonReader(new StringReader(jsonString));  

//start reading json   
reader.beginObject(); 

//get the next token 
JsonToken token = reader.peek(); 

//check the type of the token 
if (token.equals(JsonToken.NAME)) {     
   //get the current token 
   fieldname = reader.nextName(); 
}

उदाहरण

चलो देखते हैं JsonReaderकार्रवाई में। नाम से एक जावा वर्ग फ़ाइल बनाएँGsonTester C: \> GSON_WORKSPACE में।

फ़ाइल - GsonTester.java

import java.io.IOException; 
import java.io.StringReader;  

import com.google.gson.stream.JsonReader; 
import com.google.gson.stream.JsonToken;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      String jsonString = 
         "{\"name\":\"Mahesh Kumar\", \"age\":21,\"verified\":false,\"marks\": [100,90,85]}";  
      JsonReader reader = new JsonReader(new StringReader(jsonString));    
      try { 
         handleJsonObject(reader); 
      } 
      catch (IOException e) { 
         e.printStackTrace(); 
      } 
   } 
   
   private static void handleJsonObject(JsonReader reader) throws IOException { 
      reader.beginObject(); 
      String fieldname = null; 
      
      while (reader.hasNext()) { 
         JsonToken token = reader.peek(); 
         
         if (token.equals(JsonToken.BEGIN_ARRAY)) { 
            System.out.print("Marks [ "); 
            handleJsonArray(reader); 
            System.out.print("]"); 
         } else if (token.equals(JsonToken.END_OBJECT)) { 
            reader.endObject(); 
            return; 
         } else {            
            if (token.equals(JsonToken.NAME)) {     
               //get the current token 
               fieldname = reader.nextName(); 
            } 
            
            if ("name".equals(fieldname)) {       
               //move to next token 
               token = reader.peek(); 
               System.out.println("Name: "+reader.nextString());           
            } 
            
            if("age".equals(fieldname)) { 
               //move to next token 
               token = reader.peek(); 
               System.out.println("Age:" + reader.nextInt());       
            } 
            
            if("verified".equals(fieldname)) { 
               //move to next token 
               token = reader.peek(); 
               System.out.println("Verified:" + reader.nextBoolean());           
            }             
         } 
      } 
   }  
   
   private static void handleJsonArray(JsonReader reader) throws IOException { 
      reader.beginArray(); 
      String fieldname = null; 
      
      while (true) { 
         JsonToken token = reader.peek(); 
         
         if (token.equals(JsonToken.END_ARRAY)) { 
            reader.endArray(); 
            break; 
         } else if (token.equals(JsonToken.BEGIN_OBJECT)) { 
            handleJsonObject(reader); 
         } else if (token.equals(JsonToken.END_OBJECT)) { 
            reader.endObject(); 
         } else {            
            System.out.print(reader.nextInt() + " ");            
         } 
      } 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

Name: Mahesh Kumar 
Age:21 
Verified:false 
Marks [ 100 90 85 ]

इस अध्याय में, हम एरे, संग्रह और जेनेरिक के क्रमांकन / डीरियलाइज़ेशन पर चर्चा करेंगे।

ऐरे उदाहरण

int[] marks = {100,90,85}; 
//Serialization 
System.out.println("marks:" + gson.toJson(marks));        

//De-serialization 
marks = gson.fromJson("[100,90,85]", int[].class); 
System.out.println("marks:" + Arrays.toString(marks));

उदाहरण

आइए देखें एक्शन में एरियर क्रमांकन / डी-सीरियलाइज़ेशन। नाम से एक जावा वर्ग फ़ाइल बनाएँGsonTester C: \> GSON_WORKSPACE में।

File − GsonTester.java

import java.util.Arrays; 
import com.google.gson.Gson;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      Gson gson = new Gson(); 
      int[] marks = {100,90,85}; 
      String[] names = {"Ram","Shyam","Mohan"}; 
      
      //Serialization 
      System.out.print("{"); 
      System.out.print("marks:" + gson.toJson(marks) + ",");       
      System.out.print("names:" + gson.toJson(names));       
      System.out.println("}");  
      
      //De-serialization 
      marks = gson.fromJson("[100,90,85]", int[].class); 
      names = gson.fromJson("[\"Ram\",\"Shyam\",\"Mohan\"]", String[].class);
      System.out.println("marks:" + Arrays.toString(marks)); 
      System.out.println("names:" + Arrays.toString(names));     
   }      
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब परिणाम देखने के लिए GsonTester चलाएं -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{marks:[100,90,85],names:["Ram","Shyam","Mohan"]} 
marks:[100, 90, 85] 
names:[Ram, Shyam, Mohan]

संग्रह उदाहरण

List marks = new ArrayList(); 
//Serialization 
System.out.println("marks:" + gson.toJson(marks));        

//De-serialization 
//get the type of the collection. 
Type listType = new TypeToken<list>(){}.getType(); 

//pass the type of collection 
marks = gson.fromJson("[100,90,85]", listType); 
System.out.println("marks:" +marks);</list>

उदाहरण

आइये देखते हैं कलेक्शन सीरियलाइज़ेशन / डी-सीरीज़ेशन इन एक्शन। नाम से एक जावा वर्ग फ़ाइल बनाएँGsonTester C: \> GSON_WORKSPACE में।

File − GsonTester.java

import java.lang.reflect.Type; 
import java.util.ArrayList; 
import java.util.Collection;  

import com.google.gson.Gson; 
import com.google.gson.reflect.TypeToken;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      Gson gson = new Gson(); 
      Collection<Integer> marks = new ArrayList<Integer>();  
      marks.add(100); 
      marks.add(90); 
      marks.add(85);  
      
      //Serialization 
      System.out.print("{"); 
      System.out.print("marks:" + gson.toJson(marks));             
      System.out.println("}");  
      
      //De-serialization 
      Type listType = new TypeToken<Collection<Integer>>(){}.getType(); 
      marks = gson.fromJson("[100,90,85]", listType); 
      System.out.println("marks:" +marks);     
   }      
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{marks:[100,90,85]} 
marks:[100, 90, 85]

जेनरिक उदाहरण

ग्सन जावा प्रतिबिंब एपीआई का उपयोग उस वस्तु के प्रकार को प्राप्त करने के लिए करता है जिसके लिए एक जैसन पाठ को मैप किया जाना है। लेकिन जेनरिक के साथ, यह जानकारी क्रमांकन के दौरान खो जाती है। इस समस्या का सामना करने के लिए, Gson एक वर्ग प्रदान करता हैcom.google.gson.reflect.TypeToken जेनेरिक ऑब्जेक्ट के प्रकार को संग्रहीत करने के लिए।

उदाहरण

आइए देखते हैं जेनरिक सीरियलाइज़ेशन / डी-सीरीज़ेशन एक्शन में नाम से एक जावा वर्ग फ़ाइल बनाएँGsonTester C: \> GSON_WORKSPACE में।

File − GsonTester.java

import java.lang.reflect.Type; 

import com.google.gson.Gson; 
import com.google.gson.reflect.TypeToken;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      // create a shape class of type circle. 
      Shape<Circle> shape = new Shape<Circle>();  
      
      // Create a Circle object 
      Circle circle = new Circle(5.0);  
      
      //assign circle to shape 
      shape.setShape(circle);  
      Gson gson = new Gson(); 
      
      // Define a Type shapeType of type circle. 
      Type shapeType = new TypeToken<Shape<Circle>>() {}.getType();  
      
      //Serialize the json as ShapeType 
      String jsonString = gson.toJson(shape, shapeType); 
      System.out.println(jsonString);  
      Shape shape1 = gson.fromJson(jsonString, Shape.class); 
      
      System.out.println(shape1.get().getClass()); 
      System.out.println(shape1.get().toString()); 
      System.out.println(shape1.getArea());  
      Shape shape2 = gson.fromJson(jsonString, shapeType); 
      System.out.println(shape2.get().getClass()); 
      System.out.println(shape2.get().toString()); 
      System.out.println(shape2.getArea()); 
   }      
}  

class Shape <T> { 
   public T shape;  
   
   public void setShape(T shape) { 
      this.shape = shape; 
   }  
   public T get() { 
      return shape; 
   }  
   public double getArea() { 
      if(shape instanceof Circle) { 
         return ((Circle) shape).getArea(); 
      } else { 
         return 0.0; 
      } 
   } 
}  

class Circle { 
   private double radius;  
   
   public Circle(double radius){ 
      this.radius = radius; 
   }  
   public String toString() { 
      return "Circle"; 
   }  
   public double getRadius() { 
      return radius; 
   }  
   public void setRadius(double radius) { 
      this.radius = radius; 
   }  
   public double getArea() { 
      return (radius*radius*3.14); 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{"shape":{"radius":5.0}} 
class com.google.gson.internal.LinkedTreeMap 
{radius = 5.0} 
0.0 
class Circle 
Circle 
78.5

इस अध्याय में, हम आंतरिक वर्गों वाले वर्गों के क्रमांकन / विचलन का वर्णन करेंगे।

नेस्टेड इनर क्लास उदाहरण

Student student = new Student(); 
student.setRollNo(1); 
Student.Name name = student.new Name(); 
name.firstName = "Mahesh"; 
name.lastName = "Kumar"; 

student.setName(name); 
//serialize inner class object 
String nameString = gson.toJson(name); 
System.out.println(nameString); 

//deserialize inner class object   
name = gson.fromJson(nameString,Student.Name.class); 
System.out.println(name.getClass());

उदाहरण

आइए कार्रवाई में आंतरिक वर्ग के साथ वर्ग के क्रमांकन / डी-क्रमांकन का एक उदाहरण देखें। नाम से एक जावा वर्ग फ़ाइल बनाएँGsonTester C: \> GSON_WORKSPACE में।

File − GsonTester.java

import com.google.gson.Gson;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      Student student = new Student();  
      student.setRollNo(1); 
      Student.Name name = student.new Name(); 
      
      name.firstName = "Mahesh"; 
      name.lastName = "Kumar"; 
      student.setName(name); 
      Gson gson = new Gson(); 
      
      String jsonString = gson.toJson(student); 
      System.out.println(jsonString);  
      student = gson.fromJson(jsonString, Student.class);  
      
      System.out.println("Roll No: "+ student.getRollNo()); 
      System.out.println("First Name: "+ student.getName().firstName); 
      System.out.println("Last Name: "+ student.getName().lastName);  
      
      String nameString = gson.toJson(name); 
      System.out.println(nameString);  
      
      name = gson.fromJson(nameString,Student.Name.class); 
      System.out.println(name.getClass()); 
      System.out.println("First Name: "+ name.firstName); 
      System.out.println("Last Name: "+ name.lastName); 
   }      
}  

class Student { 
   private int rollNo; 
   private Name name;  
   
   public int getRollNo() { 
      return rollNo; 
   }
   
   public void setRollNo(int rollNo) { 
      this.rollNo = rollNo; 
   }  
   
   public Name getName() { 
      return name; 
   } 
   
   public void setName(Name name) { 
      this.name = name; 
   }
   
   class Name { 
      public String firstName; 
      public String lastName; 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब परिणाम देखने के लिए GsonTester चलाएं -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{"rollNo":1,"name":{"firstName":"Mahesh","lastName":"Kumar"}} 
Roll No: 1 
First Name: Mahesh 
Last Name: Kumar 

{"firstName":"Mahesh","lastName":"Kumar"} 
class Student$Name 
First Name: Mahesh 
Last Name: Kumar

नेस्टेड स्टेटिक इनर क्लास उदाहरण

Student student = new Student(); 
student.setRollNo(1); 
Student.Name name = new Student.Name(); 

name.firstName = "Mahesh"; 
name.lastName = "Kumar"; 
student.setName(name); 

//serialize static inner class object 
String nameString = gson.toJson(name); 
System.out.println(nameString); 

//deserialize static inner class object   
name = gson.fromJson(nameString,Student.Name.class); 
System.out.println(name.getClass());

उदाहरण

आइए कार्रवाई में स्थिर आंतरिक वर्ग के साथ वर्ग के क्रमांकन / डी-क्रमांकन का एक उदाहरण देखें। C: \> GSON_WORKSPACE में GsonTester नाम से जावा क्लास फ़ाइल बनाएँ।

File − GsonTester.java

import com.google.gson.Gson;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      Student student = new Student();  
      student.setRollNo(1); 
      Student.Name name = new Student.Name(); 
      
      name.firstName = "Mahesh"; 
      name.lastName = "Kumar";  
      student.setName(name); 
      
      Gson gson = new Gson(); 
      String jsonString = gson.toJson(student); 
      System.out.println(jsonString);  
      student = gson.fromJson(jsonString, Student.class);  
      
      System.out.println("Roll No: "+ student.getRollNo()); 
      System.out.println("First Name: "+ student.getName().firstName); 
      System.out.println("Last Name: "+ student.getName().lastName);  
      String nameString = gson.toJson(name); 
      System.out.println(nameString);  
      
      name = gson.fromJson(nameString,Student.Name.class); 
      System.out.println(name.getClass()); 
      System.out.println("First Name: "+ name.firstName); 
      System.out.println("Last Name: "+ name.lastName); 
   }      
}  

class Student { 
   private int rollNo; 
   private Name name;  
   
   public int getRollNo() { 
      return rollNo; 
   }  
   
   public void setRollNo(int rollNo) { 
      this.rollNo = rollNo; 
   }  
   
   public Name getName() { 
      return name; 
   }  
   
   public void setName(Name name) { 
      this.name = name; 
   } 
   
   static class Name { 
      public String firstName; 
      public String lastName; 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{"rollNo":1,"name":{"firstName":"Mahesh","lastName":"Kumar"}} 
Roll No: 1 
First Name: Mahesh 
Last Name: Kumar 

{"firstName":"Mahesh","lastName":"Kumar"} 
class Student$Name 
First Name: Mahesh 
Last Name: Kumar

ग्सन अपने इनबिल्ट एडेप्टर का उपयोग करके वस्तुओं का क्रमबद्धकरण / विचलन करता है। यह कस्टम एडेप्टर का भी समर्थन करता है। आइए चर्चा करें कि आप एक कस्टम एडेप्टर कैसे बना सकते हैं और आप इसका उपयोग कैसे कर सकते हैं।

एक कस्टम एडाप्टर बनाएँ

का विस्तार करके एक कस्टम एडेप्टर बनाएँ TypeAdapterकक्षा और इसे लक्षित वस्तु का प्रकार पास करना। ओवरराइड कियाread तथा write कस्टम डीसराइलाइजेशन और क्रमिक प्रदर्शन करने के तरीके क्रमशः।

class StudentAdapter extends TypeAdapter<Student> { 
   @Override 
   public Student read(JsonReader reader) throws IOException { 
      ... 
   } 
   
   @Override 
   public void write(JsonWriter writer, Student student) throws IOException { 
   } 
}

कस्टम एडॉप्टर पंजीकृत करें

कस्टम एडाप्टर को GsonBuilder का उपयोग करके पंजीकृत करें और उपयोग करके Gson उदाहरण बनाएं GsonBuilder

GsonBuilder builder = new GsonBuilder(); 
builder.registerTypeAdapter(Student.class, new StudentAdapter()); 
Gson gson = builder.create();

एडाप्टर का उपयोग करें

Gson अब Json पाठ को ऑब्जेक्ट में बदलने और इसके विपरीत कस्टम एडेप्टर का उपयोग करेगा।

String jsonString = "{\"name\":\"Mahesh\", \"rollNo\":1}"; 
Student student = gson.fromJson(jsonString, Student.class); 
System.out.println(student);  
jsonString = gson.toJson(student); 
System.out.println(jsonString);

उदाहरण

आइए कार्रवाई में कस्टम प्रकार एडाप्टर का एक उदाहरण देखें। नाम से एक जावा वर्ग फ़ाइल बनाएँGsonTester C: \> GSON_WORKSPACE में।

File − GsonTester.java

import java.io.IOException;  

import com.google.gson.Gson; 
import com.google.gson.GsonBuilder; 
import com.google.gson.TypeAdapter; 
import com.google.gson.stream.JsonReader; 
import com.google.gson.stream.JsonToken; 
import com.google.gson.stream.JsonWriter;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      GsonBuilder builder = new GsonBuilder(); 
      builder.registerTypeAdapter(Student.class, new StudentAdapter()); 
      builder.setPrettyPrinting(); 
      Gson gson = builder.create();  
      
      String jsonString = "{\"name\":\"Mahesh\", \"rollNo\":1}";  
      Student student = gson.fromJson(jsonString, Student.class); 
      System.out.println(student);  
      
      jsonString = gson.toJson(student); 
      System.out.println(jsonString);  
   }      
}  

class StudentAdapter extends TypeAdapter<Student> { 
   @Override 
   public Student read(JsonReader reader) throws IOException { 
      Student student = new Student(); 
      reader.beginObject(); 
      String fieldname = null; 
      
      while (reader.hasNext()) { 
         JsonToken token = reader.peek();            
         
         if (token.equals(JsonToken.NAME)) {     
            //get the current token 
            fieldname = reader.nextName(); 
         } 
         
         if ("name".equals(fieldname)) {       
            //move to next token 
            token = reader.peek(); 
            student.setName(reader.nextString()); 
         } 
         
         if("rollNo".equals(fieldname)) { 
            //move to next token 
            token = reader.peek(); 
            student.setRollNo(reader.nextInt()); 
         }               
      } 
      reader.endObject(); 
      return student; 
   }  
   
   @Override 
   public void write(JsonWriter writer, Student student) throws IOException { 
      writer.beginObject(); 
      writer.name("name"); 
      writer.value(student.getName()); 
      writer.name("rollNo"); 
      writer.value(student.getRollNo()); 
      writer.endObject(); 
   } 
}  

class Student { 
   private int rollNo; 
   private String name;  
   
   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 String toString() { 
      return "Student[ name = "+name+", roll no: "+rollNo+ "]"; 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

Student[ name = Mahesh, roll no: 1] 
{ 
   "name": "Mahesh", 
   "rollNo": 1 
}

डिफ़ॉल्ट रूप से Gson, NULL मानों की अनदेखी अनुकूलित Json सामग्री उत्पन्न करता है। लेकिन GsonBuilder Json आउटपुट में NULL मान दिखाने के लिए झंडे प्रदान करता हैGsonBuilder.serializeNulls() तरीका।

GsonBuilder builder = new GsonBuilder(); 
builder.serializeNulls(); 
Gson gson = builder.create();

बिना serializeNulls कॉल के उदाहरण

नाम से एक जावा वर्ग फ़ाइल बनाएँ GsonTester C: \> GSON_WORKSPACE में।

फ़ाइल - GsonTester.java

import com.google.gson.Gson;  

public class GsonTester { 
   public static void main(String args[]) { 
   
      Gson gson = new Gson();  
      
      Student student = new Student(); 
      student.setRollNo(1);  
      String jsonString = gson.toJson(student); 
      
      System.out.println(jsonString);  
      student = gson.fromJson(jsonString, Student.class); 
      System.out.println(student); 
   }      
} 

class Student { 
   private int rollNo; 
   private String name;  
   
   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 String toString() { 
      return "Student[ name = "+name+", roll no: "+rollNo+ "]"; 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब परिणाम देखने के लिए GsonTester चलाएं -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{"rollNo": 1} 
Student[ name = null, roll no: 1]

SerializeNulls कॉल के साथ उदाहरण

C: \> GSON_WORKSPACE में GsonTester नाम से जावा क्लास फ़ाइल बनाएँ।

फ़ाइल - 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(); 
      builder.serializeNulls(); 
      builder.setPrettyPrinting(); 
      Gson gson = builder.create();  
      
      Student student = new Student(); 
      student.setRollNo(1);  
      String jsonString = gson.toJson(student); 
      
      System.out.println(jsonString);  
      student = gson.fromJson(jsonString, Student.class); 
      System.out.println(student); 
   }      
} 
class Student { 
   private int rollNo; 
   private String name;  
   
   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 String toString() { 
      return "Student[ name = "+name+", roll no: "+rollNo+ "]"; 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब चलाओ GsonTester परिणाम देखने के लिए -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

{ 
   "rollNo": 1, 
   "name": null 
} 
Student[ name = null, roll no: 1]

Gson प्रदान करता है @Sinceअपने विभिन्न संस्करणों के आधार पर एक वर्ग के Json क्रमांकन / deserialization को नियंत्रित करने के लिए एनोटेशन। संस्करण समर्थन के साथ निम्न वर्ग पर विचार करें। इस वर्ग में, हमने शुरू में दो चर को परिभाषित किया हैrollNo तथा name और बाद में, हमने जोड़ा verifiedएक नए चर के रूप में। @Since का उपयोग करते हुए, हमने परिभाषित किया हैrollNo तथा name संस्करण 1.0 के रूप में और संस्करण 1.1 का होना सत्यापित है।

class Student { 
   @Since(1.0) 
   private int rollNo; 
   
   @Since(1.0) 
   private String name; 
   
   @Since(1.1) 
   private boolean verified;  
}

GsonBuilder प्रदान करता है setVersion() इस तरह के संस्करण वर्ग को क्रमबद्ध करने की विधि।

GsonBuilder builder = new GsonBuilder(); 
builder.setVersion(1.0);   
Gson gson = builder.create();

उदाहरण

आइए कार्रवाई में संस्करण समर्थन का एक उदाहरण देखें। नाम से एक जावा वर्ग फ़ाइल बनाएँGsonTester C: \> GSON_WORKSPACE में।

फ़ाइल - GsonTester.java

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

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

class Student { 
   @Since(1.0) 
   private int rollNo; 
   
   @Since(1.0) 
   private String name; 
   
   @Since(1.1) 
   private boolean verified;   
   
   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; 
   } 
}

परिणाम सत्यापित करें

उपयोग करने वाली कक्षाओं को संकलित करें javac संकलक निम्नानुसार है -

C:\GSON_WORKSPACE>javac GsonTester.java

अब परिणाम देखने के लिए GsonTester चलाएं -

C:\GSON_WORKSPACE>java GsonTester

आउटपुट सत्यापित करें।

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

डिफ़ॉल्ट रूप से, जीएसओएन क्रमिक / स्थिरीकरण प्रक्रिया से क्षणिक और स्थिर क्षेत्रों को बाहर करता है। आइए निम्नलिखित उदाहरण पर एक नज़र डालें।

उदाहरण

नाम से एक जावा वर्ग फ़ाइल बनाएँ 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}

बहिष्कार का उपयोग करना

GsonBuilder विशेष रूप से संशोधक के साथ क्षेत्रों को छोड़कर नियंत्रण प्रदान करता है। निम्न उदाहरण देखें।

उदाहरण

C: \> GSON_WORKSPACE में GsonTester नाम से जावा क्लास फ़ाइल बनाएँ।

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"}

@ एक्सपोज़ एनोटेशन का उपयोग करना

Gson प्रदान करता है @Exposeइसके दायरे के आधार पर एक वर्ग के Json क्रमांकन / deserialization को नियंत्रित करने के लिए एनोटेशन। एक चर वाले निम्न वर्ग पर विचार करें@Exposeसहयोग। इस वर्ग में,name तथा rollnoवैरिएशन के लिए वैरिएबल को उजागर किया जाना है तब हमने उपयोग किया हैGsonBuilder.excludeFieldsWithoutExposeAnnotation()यह इंगित करने की विधि कि केवल उजागर चर को क्रमबद्ध / deserialized किया जाना है। निम्न उदाहरण देखें।

उदाहरण

नाम से एक जावा वर्ग फ़ाइल बनाएँ 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"}