JSON.simple - Hızlı Kılavuz

JSON.simpleJSON için Java tabanlı basit bir araç setidir. JSON verilerini kodlamak veya kodunu çözmek için JSON.simple'ı kullanabilirsiniz.

Özellikleri

  • Specification Compliant - JSON.simple, JSON Spesifikasyonu - RFC4627 ile tamamen uyumludur.

  • Lightweight - Çok az sınıfı vardır ve kodlama / kod çözme ve json'dan kaçış gibi gerekli işlevleri sağlar.

  • Reuses Collections - İşlemlerin çoğu, yeniden kullanılabilirliği artıran Harita / Liste arayüzleri kullanılarak yapılır.

  • Streaming supported - JSON çıktı metninin akışını destekler.

  • SAX like Content Handler - Büyük miktarda JSON verisinin akışını sağlamak için SAX benzeri bir arayüz sağlar.

  • High performance - Yığın tabanlı ayrıştırıcı kullanılır ve yüksek performans sağlar.

  • No dependency- Harici kitaplık bağımlılığı yok. Bağımsız olarak dahil edilebilir.

  • JDK1.2 compatible - Kaynak kodu ve ikili JDK1.2 uyumludur

Yerel Ortam Kurulumu

JSON.simple, Java için bir kitaplıktır, bu nedenle ilk gereksinim, makinenize JDK'nın yüklenmiş olmasıdır.

Sistem gereksinimleri

JDK Hafıza Disk alanı İşletim sistemi
1.5 veya üstü. Minimum gereklilik yok. Minimum gereklilik yok. Minimum gereklilik yok.

Adım 1: Makinenizde Java Kurulumunu Doğrulayın

Öncelikle konsolu açın ve üzerinde çalıştığınız işletim sistemine göre bir java komutu yürütün.

işletim sistemi Görev Komut
pencereler Komut Konsolunu Aç c: \> java sürümü
Linux Komut Terminalini Aç $ java sürümü
Mac Açık Terminal machine: <joseph $ java -version

Tüm işletim sistemleri için çıktıyı doğrulayalım -

işletim sistemi Çıktı
pencereler

java sürümü "1.8.0_101"

Java (TM) SE Çalışma Zamanı Ortamı (derleme 1.8.0_101)

Linux

java sürümü "1.8.0_101"

Java (TM) SE Çalışma Zamanı Ortamı (derleme 1.8.0_101)

Mac

java sürümü "1.8.0_101"

Java (TM) SE Çalışma Zamanı Ortamı (derleme 1.8.0_101)

Sisteminizde Java kurulu değilse, Java Yazılım Geliştirme Kitini (SDK) aşağıdaki www.oracle.com bağlantısından indirin . Bu öğretici için Java 1.8.0_101 sürümünü yüklü sürüm olarak kabul ediyoruz.

Adım 2: JAVA Ortamını Ayarlayın

Yı kur JAVA_HOMEJava'nın makinenizde kurulu olduğu temel dizin konumunu gösteren ortam değişkeni. Örneğin.

işletim sistemi Çıktı
pencereler JAVA_HOME ortam değişkenini C: \ Program Files \ Java \ jdk1.8.0_101 olarak ayarlayın
Linux dışa aktar JAVA_HOME = / usr / local / java-current
Mac dışa aktar JAVA_HOME = / Kitaplık / Java / Ana Sayfa

Java derleyici konumunu Sistem Yoluna ekleyin.

işletim sistemi Çıktı
pencereler Dizeyi ekleyin C:\Program Files\Java\jdk1.8.0_101\bin sistem değişkeninin sonunda, Path.
Linux dışa aktar PATH = $ PATH: $ JAVA_HOME / bin /
Mac gerekli değil

Komutu kullanarak Java kurulumunu doğrulayın java -version yukarıda açıklandığı gibi.

3. Adım: JSON.simple Arşivini İndirin

JSON.simple jar dosyasının en son sürümünü json-simple @ MVNRepository'den indirin . Bu öğreticiyi yazarken, json-simple-1.1.1.jar dosyasını indirdik ve C: \> JSON klasörüne kopyaladık.

işletim sistemi Arşiv adı
pencereler json-simple-1.1.1.jar
Linux json-simple-1.1.1.jar
Mac json-simple-1.1.1.jar

Adım 4: JSON_JAVA Ortamını Ayarlayın

Yı kur JSON_JAVAJSON.simple jar'ın makinenizde depolandığı temel dizin konumuna işaret etmek için ortam değişkeni. JSON klasöründe json-simple-1.1.1.jar dosyasını sakladığımızı varsayalım.

Sr.No İşletim Sistemi ve Açıklama
1

Windows

JSON_JAVA ortam değişkenini C: \ JSON olarak ayarlayın

2

Linux

JSON_JAVA = / usr / local / JSON dışa aktar

3

Mac

JSON_JAVA = / Kitaplık / JSON dışa aktar

Adım 5: CLASSPATH Değişkenini Ayarlayın

Yı kur CLASSPATH JSON.simple jar konumuna işaret edecek ortam değişkeni.

Sr.No İşletim Sistemi ve Açıklama
1

Windows

Ortam değişkenini CLASSPATH olarak% CLASSPATH%;% JSON_JAVA% \ json-simple-1.1.1.jar;

2

Linux

dışa aktar CLASSPATH = $ CLASSPATH: $ JSON_JAVA / json-simple-1.1.1.jar :.

3

Mac

dışa aktar CLASSPATH = $ CLASSPATH: $ JSON_JAVA / json-simple-1.1.1.jar :.

JSON. Basit, kod çözme veya ayrıştırma sırasında varlıkları sol taraftan sağ tarafa eşler ve kodlama sırasında varlıkları sağdan sola eşler.

JSON Java
dizi java.lang.String
numara java.lang.Number
doğru | yanlış java.lang.Boolean
boş boş
dizi java.util.List
nesne java.util.Map

Kod çözme günü, varsayılan beton sınıfı java.util.List olan org.json.simple.JSONArray ve varsayılan beton sınıfı java.util.Map olduğunu org.json.simple.JSONObject .

Aşağıdaki karakterler ayrılmış karakterlerdir ve JSON'da kullanılamaz ve dizelerde kullanılmak üzere uygun şekilde öncelenmelidir.

  • Backspace \ b ile değiştirilecek

  • Form feed \ f ile değiştirilecek

  • Newline \ n ile değiştirilecek

  • Carriage return \ r ile değiştirilecek

  • Tab \ t ile değiştirilecek

  • Double quote \ "ile değiştirilecek

  • Backslash \\ ile değiştirilecek

JSONObject.escape()yöntemi, bir JSON Dizesinde bu tür ayrılmış anahtar sözcüklerden kaçış yapmak için kullanılabilir. Örnek aşağıdadır -

Misal

import org.json.simple.JSONObject;

public class JsonDemo {
   public static void main(String[] args) {
      JSONObject jsonObject = new JSONObject();
      String text = "Text with special character /\"\'\b\f\t\r\n.";
      System.out.println(text);
      System.out.println("After escaping.");
      text = jsonObject.escape(text);
      System.out.println(text);
   }
}

Çıktı

Text with special character /"'
.
After escaping.
Text with special character \/\"'\b\f\t\r\n.

JSONValue, daha sonra ayrıştırılan değerleri almak için kullanılabilen bir JSONObject döndürmek için verilen json dizesini ayrıştırmak için statik bir yöntem parse () sağlar. Aşağıdaki örneğe bakın.

Misal

import org.json.simple.JSONArray;
import org.json.simple.JSONObject;
import org.json.simple.JSONValue;

public class JsonDemo {
   public static void main(String[] args) {
      String s = "[0,{\"1\":{\"2\":{\"3\":{\"4\":[5,{\"6\":7}]}}}}]";
      Object obj = JSONValue.parse(s);
      JSONArray array = (JSONArray)obj;

      System.out.println("The 2nd element of array");
      System.out.println(array.get(1));
      System.out.println();

      JSONObject obj2 = (JSONObject)array.get(1);
      System.out.println("Field \"1\"");
      System.out.println(obj2.get("1"));    

      s = "{}";
      obj = JSONValue.parse(s);
      System.out.println(obj);

      s = "[5,]";
      obj = JSONValue.parse(s);
      System.out.println(obj);

      s = "[5,,2]";
      obj = JSONValue.parse(s);
      System.out.println(obj);
   }
}

Çıktı

The 2nd element of array
{"1":{"2":{"3":{"4":[5,{"6":7}]}}}}

Field "1"
{"2":{"3":{"4":[5,{"6":7}]}}}
{}
[5]
[5,2]

JSONParser.parse (), geçersiz JSON durumunda ParseException oluşturur. Aşağıdaki örnek, ParseException'ın nasıl işleneceğini gösterir.

Misal

import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException;

class JsonDemo {
   public static void main(String[] args) {
      JSONParser parser = new JSONParser();
      String text = "[[null, 123.45, \"a\tb c\"]}, true";

      try{
         Object obj = parser.parse(text);         
         System.out.println(obj);
      }catch(ParseException pe) {
         System.out.println("position: " + pe.getPosition());
         System.out.println(pe);
      }
   }
}

Çıktı

position: 24
Unexpected token RIGHT BRACE(}) at position 24.

ContainerFactory, ayrıştırılmış JSON nesneleri / dizileri için Özel kapsayıcı oluşturmak için kullanılabilir. Öncelikle bir ContainerFactory nesnesi oluşturmamız ve daha sonra gerekli nesneyi elde etmek için JSONParser'ın ayrıştırma Yönteminde kullanmamız gerekiyor. Aşağıdaki örneğe bakın -

Misal

import java.util.LinkedHashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

import org.json.simple.parser.ContainerFactory;
import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException;

class JsonDemo {
   public static void main(String[] args) {
      JSONParser parser = new JSONParser();
      String text =  "{\"first\": 123, \"second\": [4, 5, 6], \"third\": 789}";
      ContainerFactory containerFactory = new ContainerFactory() {
         @Override
         public Map createObjectContainer() {
            return new LinkedHashMap<>();
         }
         @Override
         public List creatArrayContainer() {
            return new LinkedList<>();
         }
      };
      try {
         Map map = (Map)parser.parse(text, containerFactory);       
         map.forEach((k,v)->System.out.println("Key : " + k + " Value : " + v));
      } catch(ParseException pe) {
         System.out.println("position: " + pe.getPosition());
         System.out.println(pe);
      }
   }
}

Çıktı

Key : first Value : 123
Key : second Value : [4, 5, 6]
Key : third Value : 789

ContentHandler arabirimi, büyük json'u akışa almak için SAX benzeri bir arabirim sağlamak için kullanılır. Durdurulabilirlik de sağlar. Aşağıdaki örnek kavramı göstermektedir.

Misal

import java.io.IOException;
import java.util.List;
import java.util.Stack;

import org.json.simple.JSONArray;
import org.json.simple.JSONObject;
import org.json.simple.parser.ContentHandler;
import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException;

class JsonDemo {
   public static void main(String[] args) {
      JSONParser parser = new JSONParser();
      String text =  "{\"first\": 123, \"second\": [4, 5, 6], \"third\": 789}";
      try {
         CustomContentHandler handler = new CustomContentHandler();
         parser.parse(text, handler,true);       
      } catch(ParseException pe) {
      }
   }
}
class CustomContentHandler implements ContentHandler {
   @Override
   public boolean endArray() throws ParseException, IOException {     
      System.out.println("inside endArray");
      return true;
   }
   @Override
   public void endJSON() throws ParseException, IOException {
      System.out.println("inside endJSON");
   }
   @Override
   public boolean endObject() throws ParseException, IOException {       
      System.out.println("inside endObject");
      return true;
   }
   @Override
   public boolean endObjectEntry() throws ParseException, IOException {
      System.out.println("inside endObjectEntry");
      return true;
   }
   public boolean primitive(Object value) throws ParseException, IOException {
      System.out.println("inside primitive: " + value);
      return true;
   }
   @Override
   public boolean startArray() throws ParseException, IOException {
      System.out.println("inside startArray");
      return true;
   }
   @Override
   public void startJSON() throws ParseException, IOException {
      System.out.println("inside startJSON");
   }
   @Override
   public boolean startObject() throws ParseException, IOException {
      System.out.println("inside startObject");      
      return true;
   }
   @Override
   public boolean startObjectEntry(String key) throws ParseException, IOException {
      System.out.println("inside startObjectEntry: " + key); 
      return true;
   }    
}

Çıktı

inside startJSON
inside startObject
inside startObjectEntry: first
inside primitive: 123
inside endObjectEntry
inside startObjectEntry: second
inside startArray
inside primitive: 4
inside primitive: 5
inside primitive: 6
inside endArray
inside endObjectEntry
inside startObjectEntry: third
inside primitive: 789
inside endObjectEntry
inside endObject
inside endJSON

JSON.simple kullanarak, aşağıdaki yolları kullanarak bir JSON Nesnesini kodlayabiliriz -

  • Encode a JSON Object - to String - Basit kodlama.

  • Encode a JSON Object - Streaming - Çıkış, akış için kullanılabilir.

  • Encode a JSON Object - Using Map - Sırayı koruyarak kodlama.

  • Encode a JSON Object - Using Map and Streaming - Sırayı koruyarak ve akışı koruyarak kodlama.

Aşağıdaki örnek, yukarıdaki kavramları göstermektedir.

Misal

import java.io.IOException;
import java.io.StringWriter;
import java.util.LinkedHashMap;
import java.util.Map;

import org.json.simple.JSONObject;
import org.json.simple.JSONValue;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      JSONObject obj = new JSONObject();
      String jsonText;

      obj.put("name", "foo");
      obj.put("num", new Integer(100));
      obj.put("balance", new Double(1000.21));
      obj.put("is_vip", new Boolean(true));
      jsonText = obj.toString();

      System.out.println("Encode a JSON Object - to String");
      System.out.print(jsonText);

      StringWriter out = new StringWriter();
      obj.writeJSONString(out);       
      jsonText = out.toString();

      System.out.println("\nEncode a JSON Object - Streaming");       
      System.out.print(jsonText);

      Map obj1 = new LinkedHashMap();
      obj1.put("name", "foo");
      obj1.put("num", new Integer(100));
      obj1.put("balance", new Double(1000.21));
      obj1.put("is_vip", new Boolean(true));

      jsonText = JSONValue.toJSONString(obj1); 
      System.out.println("\nEncode a JSON Object - Preserving Order");
      System.out.print(jsonText);

      out = new StringWriter();
      JSONValue.writeJSONString(obj1, out); 
      jsonText = out.toString();
      System.out.println("\nEncode a JSON Object - Preserving Order and Stream");
      System.out.print(jsonText);
   }
}

Çıktı

Encode a JSON Object - to String
{"balance":1000.21,"is_vip":true,"num":100,"name":"foo"}
Encode a JSON Object - Streaming
{"balance":1000.21,"is_vip":true,"num":100,"name":"foo"}
Encode a JSON Object - Preserving Order
{"name":"foo","num":100,"balance":1000.21,"is_vip":true}
Encode a JSON Object - Preserving Order and Stream
{"name":"foo","num":100,"balance":1000.21,"is_vip":true}

JSON.simple kullanarak, aşağıdaki yolları kullanarak bir JSON Dizisini kodlayabiliriz -

  • Encode a JSON Array - to String - Basit kodlama.

  • Encode a JSON Array - Streaming - Çıkış, akış için kullanılabilir.

  • Encode a JSON Array - Using List - Listeyi kullanarak kodlama.

  • Encode a JSON Array - Using List and Streaming - Liste kullanarak kodlama ve akış.

Aşağıdaki örnek, yukarıdaki kavramları göstermektedir.

Misal

import java.io.IOException;
import java.io.StringWriter;
import java.util.LinkedList;
import java.util.List;

import org.json.simple.JSONArray;
import org.json.simple.JSONValue;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      JSONArray list = new JSONArray();
      String jsonText;

      list.add("foo");
      list.add(new Integer(100));
      list.add(new Double(1000.21));
      list.add(new Boolean(true));
      list.add(null);
      jsonText = list.toString();

      System.out.println("Encode a JSON Array - to String");
      System.out.print(jsonText);

      StringWriter out = new StringWriter();
      list.writeJSONString(out);       
      jsonText = out.toString();

      System.out.println("\nEncode a JSON Array - Streaming");       
      System.out.print(jsonText);

      List list1 = new LinkedList();
      list1.add("foo");
      list1.add(new Integer(100));
      list1.add(new Double(1000.21));
      list1.add(new Boolean(true));
      list1.add(null);

      jsonText = JSONValue.toJSONString(list1); 
      System.out.println("\nEncode a JSON Array - Using List");
      System.out.print(jsonText);

      out = new StringWriter();
      JSONValue.writeJSONString(list1, out); 
      jsonText = out.toString();
      System.out.println("\nEncode a JSON Array - Using List and Stream");
      System.out.print(jsonText);
   }
}

Çıktı

Encode a JSON Array - to String
["foo",100,1000.21,true,null]
Encode a JSON Array - Streaming
["foo",100,1000.21,true,null]
Encode a JSON Array - Using List
["foo",100,1000.21,true,null]
Encode a JSON Array - Using List and Stream
["foo",100,1000.21,true,null]

JSON.simple'da, JSONObject.putAll () yöntemini kullanarak iki JSON Nesnesini kolayca birleştirebiliriz.

Aşağıdaki örnek, yukarıdaki kavramı göstermektedir.

Misal

import java.io.IOException;
import org.json.simple.JSONObject;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      JSONObject obj1 = new JSONObject();       
      obj1.put("name", "foo");
      obj1.put("num", new Integer(100)); 

      JSONObject obj2 = new JSONObject();       
      obj2.put("balance", new Double(1000.21));
      obj2.put("is_vip", new Boolean(true));       
      obj1.putAll(obj2);       
      System.out.println(obj1);
   }
}

Çıktı

{"balance":1000.21,"is_vip":true,"num":100,"name":"foo"}

JSON.simple'da, JSONArray.addAll () yöntemini kullanarak iki JSON Dizisini kolayca birleştirebiliriz.

Aşağıdaki örnek, yukarıdaki kavramı göstermektedir.

Misal

import java.io.IOException;
import org.json.simple.JSONArray;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      JSONArray list1 = new JSONArray();
      list1.add("foo");
      list1.add(new Integer(100));

      JSONArray list2 = new JSONArray();       
      list2.add(new Double(1000.21));
      list2.add(new Boolean(true));
      list2.add(null);

      list1.addAll(list2);       
      System.out.println(list1);       
   }
}

Çıktı

["foo",100,1000.21,true,null]

JSONArray nesnesini kullanarak ilkellerden, nesneden ve diziden oluşan bir JSON oluşturabiliriz.

Aşağıdaki örnek, yukarıdaki kavramı göstermektedir.

Misal

import java.io.IOException;
import org.json.simple.JSONArray;
import org.json.simple.JSONObject;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      JSONArray list1 = new JSONArray();
      list1.add("foo");
      list1.add(new Integer(100));

      JSONArray list2 = new JSONArray();       
      list2.add(new Double(1000.21));
      list2.add(new Boolean(true));
      list2.add(null);

      JSONObject obj = new JSONObject();

      obj.put("name", "foo");
      obj.put("num", new Integer(100));
      obj.put("balance", new Double(1000.21));
      obj.put("is_vip", new Boolean(true));
     
      obj.put("list1", list1); 
      obj.put("list2", list2);
      System.out.println(obj);       
   }
}

Çıktı

{"list1":["foo",100],"balance":1000.21,"is_vip":true,"num":100,"list2":[1000.21,true,null],"name":"foo"}

JSONValue nesnesini kullanarak temel öğeler, Harita ve Listeden oluşan bir JSON oluşturabiliriz.

Aşağıdaki örnek, yukarıdaki kavramı göstermektedir.

Misal

import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

import org.json.simple.JSONValue;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      Map m1 = new LinkedHashMap(); 
      m1.put("k11","v11"); 
      m1.put("k12","v12"); 
      m1.put("k13", "v13");

      List l1 = new LinkedList();
      l1.add(m1);
      l1.add(new Integer(100));

      String jsonString = JSONValue.toJSONString(l1);
      System.out.println(jsonString);
   }
}

Çıktı

[{"k11":"v11","k12":"v12","k13":"v13"},100]

JSONValue nesnesini kullanarak temel öğeler, Nesne, Harita ve Listeden oluşan bir JSON oluşturabiliriz.

Aşağıdaki örnek, yukarıdaki kavramı göstermektedir.

Misal

import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

import org.json.simple.JSONObject;
import org.json.simple.JSONValue;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      JSONObject obj = new JSONObject();

      Map m1 = new LinkedHashMap(); 
      m1.put("k11","v11");
      m1.put("k12","v12");
      m1.put("k13", "v13");

      List l1 = new LinkedList();      
      l1.add(new Integer(100));

      obj.put("m1", m1);
      obj.put("l1", l1);
      String jsonString = JSONValue.toJSONString(obj);
      System.out.println(jsonString);
   }
}

Çıktı

{"m1":{"k11":"v11","k12":"v12","k13":"v13"},"l1":[100]}

JSON çıktısını özel sınıfa göre özelleştirebiliriz. Tek gereksinim JSONAware arayüzünü uygulamaktır.

Aşağıdaki örnek, yukarıdaki kavramı göstermektedir.

Misal

import java.io.IOException;

import org.json.simple.JSONArray;
import org.json.simple.JSONAware;
import org.json.simple.JSONObject;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      JSONArray students = new JSONArray(); 
      students.add(new Student(1,"Robert")); 
      students.add(new Student(2,"Julia")); 

      System.out.println(students);     
   }
}
class Student implements JSONAware {
   int rollNo;
   String name;
   Student(int rollNo, String name){
      this.rollNo = rollNo;
      this.name = name;
   }
   @Override
   public String toJSONString() {
      StringBuilder sb = new StringBuilder();
      sb.append("{");
      sb.append("name");
      sb.append(":");
      sb.append("\"" + JSONObject.escape(name) + "\"");
      sb.append(",");
      sb.append("rollNo");
      sb.append(":");
      sb.append(rollNo);
      sb.append("}");
      return sb.toString();
   }    
}

Çıktı

[{name:"Robert",rollNo:1},{name:"Julia",rollNo:2}]

JSON akış çıktısını özel sınıfa göre özelleştirebiliriz. Tek gereksinim JSONStreamAware arayüzünü uygulamaktır.

Aşağıdaki örnek, yukarıdaki kavramı göstermektedir.

Misal

import java.io.IOException;
import java.io.StringWriter;
import java.io.Writer;
import java.util.LinkedHashMap;
import java.util.Map;

import org.json.simple.JSONArray;
import org.json.simple.JSONStreamAware;
import org.json.simple.JSONValue;

class JsonDemo {
   public static void main(String[] args) throws IOException {
      JSONArray students = new JSONArray(); 
      students.add(new Student(1,"Robert")); 
      students.add(new Student(2,"Julia")); 
      StringWriter out = new StringWriter();
      students.writeJSONString(out); 
      System.out.println(out.toString());     
   }
}
class Student implements JSONStreamAware {
   int rollNo;
   String name;

   Student(int rollNo, String name){
      this.rollNo = rollNo;
      this.name = name;
   }
   @Override
   public void writeJSONString(Writer out) throws IOException {
      Map obj = new LinkedHashMap();
      obj.put("name", name);
      obj.put("rollNo", new Integer(rollNo));
      JSONValue.writeJSONString(obj, out);        
   }    
}

Çıktı

[{name:"Robert",rollNo:1},{name:"Julia",rollNo:2}]