Jackson - Datenbindung

Die Datenbindungs-API wird verwendet, um JSON mithilfe von Eigenschaftszugriff oder Anmerkungen in und von POJO (Plain Old Java Object) zu konvertieren. Es ist von zwei Arten.

  • Simple Data Binding - Konvertiert JSON in und von Java Maps, Listen, Strings, Numbers, Booleans und Null-Objekten.

  • Full Data Binding - Konvertiert JSON in und von einem beliebigen JAVA-Typ.

ObjectMapper liest / schreibt JSON für beide Arten von Datenbindungen. Die Datenbindung ist am bequemsten und entspricht dem JAXB-Parer für XML.

Einfache Datenbindung

Einfache Datenbindung bezieht sich auf die Zuordnung von JSON zu JAVA Core-Datentypen. Die folgende Tabelle zeigt die Beziehung zwischen JSON-Typen und Java-Typen.

Sr. Nr. JSON-Typ Java-Typ
1 Objekt LinkedHashMap <String, Objekt>
2 Array ArrayList <Objekt>
3 Zeichenfolge String
4 vollständige Nummer Integer, Long oder BigInteger
5 Bruchzahl Double / BigDecimal
6 wahr | falsch Boolescher Wert
7 Null Null

Lassen Sie uns die einfache Datenbindung in Aktion sehen. Hier ordnen wir JAVA-Basistypen direkt JSON zu und umgekehrt.

Erstellen Sie eine Java-Klassendatei mit dem Namen JacksonTester in C:\>Jackson_WORKSPACE.

Datei: JacksonTester.java

import java.io.File;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.ObjectMapper;

public class JacksonTester {
   public static void main(String args[]){
      JacksonTester tester = new JacksonTester();
         try {
            ObjectMapper mapper = new ObjectMapper();

            Map<String,Object> studentDataMap = new HashMap<String,Object>(); 
            int[] marks = {1,2,3};

            Student student = new Student();
            student.setAge(10);
            student.setName("Mahesh");
            // JAVA Object
            studentDataMap.put("student", student);
            // JAVA String
            studentDataMap.put("name", "Mahesh Kumar");   		
            // JAVA Boolean
            studentDataMap.put("verified", Boolean.FALSE);
            // Array
            studentDataMap.put("marks", marks);

            mapper.writeValue(new File("student.json"), studentDataMap);
            //result student.json
			//{ 
            //   "student":{"name":"Mahesh","age":10},
            //   "marks":[1,2,3],
            //   "verified":false,
            //   "name":"Mahesh Kumar"
            //}
            studentDataMap = mapper.readValue(new File("student.json"), Map.class);

            System.out.println(studentDataMap.get("student"));
            System.out.println(studentDataMap.get("name"));
            System.out.println(studentDataMap.get("verified"));
            System.out.println(studentDataMap.get("marks"));
      } catch (JsonParseException e) {
         e.printStackTrace();
      } catch (JsonMappingException e) {
         e.printStackTrace();
      } catch (IOException e) {
            e.printStackTrace();
      }
   }
}

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+ " ]";
   }	
}

Verify the result

Kompilieren Sie die Klassen mit javac Compiler wie folgt:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Führen Sie nun den jacksonTester aus, um das Ergebnis anzuzeigen:

C:\Jackson_WORKSPACE>java JacksonTester

Überprüfen Sie die Ausgabe

{name=Mahesh, age=10}
Mahesh Kumar
false
[1, 2, 3]

Vollständige Datenbindung

Datenbindung mit Generika