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