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