JSON.simple - Guide rapide

JSON.simpleest une boîte à outils Java simple pour JSON. Vous pouvez utiliser JSON.simple pour encoder ou décoder des données JSON.

traits

  • Specification Compliant - JSON.simple est entièrement conforme à la spécification JSON - RFC4627.

  • Lightweight - Il a très peu de classes et fournit les fonctionnalités nécessaires comme encoder / décoder et échapper json.

  • Reuses Collections - La plupart des opérations sont effectuées à l'aide d'interfaces Map / List augmentant la réutilisabilité.

  • Streaming supported - Prend en charge la diffusion en continu du texte de sortie JSON.

  • SAX like Content Handler - Fournit une interface de type SAX pour diffuser une grande quantité de données JSON.

  • High performance - Un analyseur basé sur le tas est utilisé et offre des performances élevées.

  • No dependency- Aucune dépendance de bibliothèque externe. Peut être inclus indépendamment.

  • JDK1.2 compatible - Le code source et le binaire sont compatibles JDK1.2

Configuration de l'environnement local

JSON.simple est une bibliothèque pour Java, donc la toute première exigence est d'avoir JDK installé sur votre machine.

Exigence du système

JDK Mémoire Espace disque Système opérateur
1.5 ou supérieur. Aucune exigence minimale. Aucune exigence minimale. Aucune exigence minimale.

Étape 1: Vérifiez l'installation de Java sur votre machine

Tout d'abord, ouvrez la console et exécutez une commande java basée sur le système d'exploitation sur lequel vous travaillez.

OS Tâche Commander
les fenêtres Ouvrez la console de commande c: \> java -version
Linux Ouvrir le terminal de commande $ java -version
Mac Terminal ouvert machine: <joseph $ java -version

Vérifions la sortie pour tous les systèmes d'exploitation -

OS Production
les fenêtres

version java "1.8.0_101"

Environnement d'exécution Java (TM) SE (build 1.8.0_101)

Linux

version java "1.8.0_101"

Environnement d'exécution Java (TM) SE (build 1.8.0_101)

Mac

version java "1.8.0_101"

Environnement d'exécution Java (TM) SE (build 1.8.0_101)

Si Java n'est pas installé sur votre système, téléchargez le kit de développement logiciel Java (SDK) à partir du lien suivant www.oracle.com . Nous supposons que Java 1.8.0_101 est la version installée pour ce didacticiel.

Étape 2: définir l'environnement JAVA

Met le JAVA_HOMEvariable d'environnement pour pointer vers l'emplacement du répertoire de base où Java est installé sur votre machine. Par exemple.

OS Production
les fenêtres Définissez la variable d'environnement JAVA_HOME sur C: \ Program Files \ Java \ jdk1.8.0_101
Linux export JAVA_HOME = / usr / local / java-current
Mac export JAVA_HOME = / Bibliothèque / Java / Accueil

Ajoutez l'emplacement du compilateur Java au chemin système.

OS Production
les fenêtres Ajouter la chaîne C:\Program Files\Java\jdk1.8.0_101\bin à la fin de la variable système, Path.
Linux export PATH = $ PATH: $ JAVA_HOME / bin /
Mac non requis

Vérifiez l'installation de Java à l'aide de la commande java -version comme expliqué ci-dessus.

Étape 3: Téléchargez l'archive JSON.simple

Téléchargez la dernière version du fichier jar JSON.simple à partir de json-simple @ MVNRepository . Au moment de la rédaction de ce didacticiel, nous avons téléchargé json-simple-1.1.1.jar et l'avons copié dans le dossier C: \> JSON.

OS Nom de l'archive
les fenêtres json-simple-1.1.1.jar
Linux json-simple-1.1.1.jar
Mac json-simple-1.1.1.jar

Étape 4: définir l'environnement JSON_JAVA

Met le JSON_JAVAvariable d'environnement pour pointer vers l'emplacement du répertoire de base où JSON.simple jar est stocké sur votre machine. Supposons que nous ayons stocké json-simple-1.1.1.jar dans le dossier JSON.

Sr. Non OS et description
1

Windows

Définissez la variable d'environnement JSON_JAVA sur C: \ JSON

2

Linux

exporter JSON_JAVA = / usr / local / JSON

3

Mac

export JSON_JAVA = / Bibliothèque / JSON

Étape 5: Définissez la variable CLASSPATH

Met le CLASSPATH variable d'environnement pour pointer vers l'emplacement du fichier JSON.simple.

Sr. Non OS et description
1

Windows

Définissez la variable d'environnement CLASSPATH sur% CLASSPATH%;% JSON_JAVA% \ json-simple-1.1.1.jar;.;

2

Linux

export CLASSPATH = $ CLASSPATH: $ JSON_JAVA / json-simple-1.1.1.jar :.

3

Mac

export CLASSPATH = $ CLASSPATH: $ JSON_JAVA / json-simple-1.1.1.jar :.

JSON.simple mappe les entités du côté gauche vers le côté droit lors du décodage ou de l'analyse, et mappe les entités de la droite vers la gauche lors du codage.

JSON Java
chaîne java.lang.String
nombre java.lang.Number
vrai | faux java.lang.Boolean
nul nul
tableau java.util.List
objet java.util.Map

Lors du décodage, la classe concrète par défaut de java.util.List est org.json.simple.JSONArray et la classe concrète par défaut de java.util.Map est org.json.simple.JSONObject .

Les caractères suivants sont des caractères réservés et ne peuvent pas être utilisés dans JSON et doivent être correctement échappés pour être utilisés dans les chaînes.

  • Backspace à remplacer par \ b

  • Form feed à remplacer par \ f

  • Newline à remplacer par \ n

  • Carriage return à remplacer par \ r

  • Tab à remplacer par \ t

  • Double quote à remplacer par \ "

  • Backslash à remplacer par \\

JSONObject.escape()peut être utilisée pour échapper à ces mots-clés réservés dans une chaîne JSON. Voici l'exemple -

Exemple

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);
   }
}

Production

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

JSONValue fournit une méthode statique parse () pour analyser la chaîne json donnée pour renvoyer un JSONObject qui peut ensuite être utilisé pour obtenir les valeurs analysées. Voir l'exemple ci-dessous.

Exemple

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);
   }
}

Production

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 () lève ParseException en cas de JSON invalide. L'exemple suivant montre comment gérer ParseException.

Exemple

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);
      }
   }
}

Production

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

ContainerFactory peut être utilisé pour créer un conteneur personnalisé pour les objets / tableaux JSON analysés. Nous devons d'abord créer un objet ContainerFactory, puis l'utiliser dans la méthode d'analyse de JSONParser pour obtenir l'objet requis. Voir l'exemple ci-dessous -

Exemple

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);
      }
   }
}

Production

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

L'interface ContentHandler est utilisée pour fournir une interface de type SAX pour diffuser le grand json. Il fournit également une capacité d'arrêt. L'exemple suivant illustre le concept.

Exemple

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

Production

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

En utilisant JSON.simple, nous pouvons encoder un objet JSON en utilisant les méthodes suivantes -

  • Encode a JSON Object - to String - Encodage simple.

  • Encode a JSON Object - Streaming - La sortie peut être utilisée pour le streaming.

  • Encode a JSON Object - Using Map - Encodage en préservant la commande.

  • Encode a JSON Object - Using Map and Streaming - Encodage en préservant l'ordre et en streaming.

L'exemple suivant illustre les concepts ci-dessus.

Exemple

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);
   }
}

Production

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}

En utilisant JSON.simple, nous pouvons encoder un tableau JSON en utilisant les méthodes suivantes:

  • Encode a JSON Array - to String - Encodage simple.

  • Encode a JSON Array - Streaming - La sortie peut être utilisée pour le streaming.

  • Encode a JSON Array - Using List - Encodage à l'aide de la liste.

  • Encode a JSON Array - Using List and Streaming - Encodage en utilisant List et pour diffuser.

L'exemple suivant illustre les concepts ci-dessus.

Exemple

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);
   }
}

Production

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]

Dans JSON.simple, nous pouvons facilement fusionner deux objets JSON à l'aide de la méthode JSONObject.putAll ().

L'exemple suivant illustre le concept ci-dessus.

Exemple

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);
   }
}

Production

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

Dans JSON.simple, nous pouvons facilement fusionner deux tableaux JSON à l'aide de la méthode JSONArray.addAll ().

L'exemple suivant illustre le concept ci-dessus.

Exemple

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);       
   }
}

Production

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

En utilisant un objet JSONArray, nous pouvons créer un JSON qui comprend des primitives, un objet et un tableau.

L'exemple suivant illustre le concept ci-dessus.

Exemple

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);       
   }
}

Production

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

En utilisant l'objet JSONValue, nous pouvons créer un JSON qui comprend des primitives, une carte et une liste.

L'exemple suivant illustre le concept ci-dessus.

Exemple

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);
   }
}

Production

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

En utilisant l'objet JSONValue, nous pouvons créer un JSON qui comprend des primitives, un objet, une carte et une liste.

L'exemple suivant illustre le concept ci-dessus.

Exemple

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);
   }
}

Production

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

Nous pouvons personnaliser la sortie JSON en fonction de la classe personnalisée. La seule exigence est d'implémenter l'interface JSONAware.

L'exemple suivant illustre le concept ci-dessus.

Exemple

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();
   }    
}

Production

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

Nous pouvons personnaliser la sortie de streaming JSON en fonction de la classe personnalisée. La seule exigence est d'implémenter l'interface JSONStreamAware.

L'exemple suivant illustre le concept ci-dessus.

Exemple

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);        
   }    
}

Production

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