Jackson - Guide rapide

Jackson est une bibliothèque Java simple pour sérialiser des objets Java en JSON et vice versa.

traits

  • Easy to use. - L'API jackson fournit une façade de haut niveau pour simplifier les cas d'utilisation courants.

  • No need to create mapping. - L'API jackson fournit un mappage par défaut pour la plupart des objets à sérialiser.

  • Performance. - jackson est silencieux et rapide et a une faible empreinte mémoire et convient aux grands graphiques ou systèmes d'objets.

  • Clean JSON. - jackson crée des résultats JSON propres et compacts, faciles à lire.

  • No Dependency. - la bibliothèque jackson ne nécessite aucune autre bibliothèque en dehors de jdk.

  • Open Source - La bibliothèque jackson est open source et est gratuite.

Trois façons de traiter JSON

Jackson propose trois méthodes alternatives pour traiter JSON

  • Streaming API- lit et écrit le contenu JSON en tant qu'événements discrets. JsonParser lit les données tandis que JsonGenerator écrit les données. C'est l'approche la plus puissante parmi les trois, la plus faible surcharge et la plus rapide dans les opérations de lecture / écriture. C'est l'analyseur Analogus to Stax pour XML.

  • Tree Model- prépare une représentation arborescente en mémoire du document JSON. ObjectMapper crée l'arborescence des nœuds JsonNode. C'est l'approche la plus flexible. Il est analogue à l'analyseur DOM pour XML.

  • Data Binding - convertit JSON vers et depuis POJO (Plain Old Java Object) en utilisant l'accesseur de propriété ou en utilisant des annotations. Il est de deux types.

    • Simple Data Binding - Convertit JSON vers et depuis Java Maps, Lists, Strings, Numbers, Booleans et objets null.

    • Full Data Binding - Convertit JSON vers et depuis n'importe quel type JAVA.

    ObjectMapper lit / écrit JSON pour les deux types de liaisons de données. La liaison de données est le moyen le plus pratique et est analogue au parer JAXB pour XML.

Essayez-le Option en ligne

Vous n'avez vraiment pas besoin de configurer votre propre environnement pour commencer à apprendre Guava, une bibliothèque basée sur JAVA. La raison est très simple, nous avons déjà configuré l'environnement de programmation Java en ligne, afin que vous puissiez compiler et exécuter tous les exemples disponibles en ligne en même temps lorsque vous faites votre travail théorique. Cela vous donne confiance dans ce que vous lisez et de vérifier le résultat avec différentes options. N'hésitez pas à modifier n'importe quel exemple et à l'exécuter en ligne.

Essayez l'exemple suivant en utilisant Try it option disponible dans le coin supérieur droit de l'exemple de code ci-dessous:

public class MyFirstJavaProgram {

    public static void main(String []args) {
       System.out.println("Hello World");
    }
}

Pour la plupart des exemples donnés dans ce tutoriel, vous trouverez Try it option, alors profitez-en et profitez de votre apprentissage.

Configuration de l'environnement local

Si vous souhaitez toujours configurer votre environnement pour le langage de programmation Java, cette section vous explique comment télécharger et configurer Java sur votre machine. Veuillez suivre les étapes suivantes pour configurer l'environnement.

Java SE est disponible gratuitement à partir du lien Télécharger Java . Vous téléchargez donc une version basée sur votre système d'exploitation.

Suivez les instructions pour télécharger java et exécuter le .exepour installer Java sur votre machine. Une fois que vous avez installé Java sur votre machine, vous devez définir des variables d'environnement pour qu'elles pointent vers les répertoires d'installation corrects:

Configuration du chemin pour Windows 2000 / XP:

En supposant que vous ayez installé Java dans le répertoire c: \ Program Files \ java \ jdk :

  • Cliquez avec le bouton droit sur «Poste de travail» et sélectionnez «Propriétés».

  • Cliquez sur le bouton «Variables d'environnement» sous l'onglet «Avancé».

  • Maintenant, modifiez la variable «Path» afin qu'elle contienne également le chemin vers l'exécutable Java. Exemple, si le chemin est actuellement défini sur «C: \ WINDOWS \ SYSTEM32», modifiez votre chemin pour lire «C: \ WINDOWS \ SYSTEM32; c: \ Program Files \ java \ jdk \ bin».

Configuration du chemin pour Windows 95/98 / ME:

En supposant que vous ayez installé Java dans le répertoire c: \ Program Files \ java \ jdk :

  • Modifiez le fichier 'C: \ autoexec.bat' et ajoutez la ligne suivante à la fin:
    'SET PATH =% PATH%; C: \ Program Files \ java \ jdk \ bin'

Configuration du chemin pour Linux, UNIX, Solaris, FreeBSD:

La variable d'environnement PATH doit être définie pour pointer vers l'endroit où les binaires Java ont été installés. Reportez-vous à la documentation de votre shell si vous rencontrez des problèmes pour cela.

Exemple, si vous utilisez bash comme shell, vous ajouteriez la ligne suivante à la fin de votre '.bashrc: export PATH = / path / to / java: $ PATH'

Éditeurs Java populaires:

Pour écrire vos programmes Java, vous aurez besoin d'un éditeur de texte. Il existe des IDE encore plus sophistiqués disponibles sur le marché. Mais pour l'instant, vous pouvez envisager l'un des éléments suivants:

  • Notepad: Sur la machine Windows, vous pouvez utiliser n'importe quel éditeur de texte simple comme Notepad (recommandé pour ce didacticiel), TextPad.

  • Netbeans:est un IDE Java open-source et gratuit qui peut être téléchargé depuis http://www.netbeans.org/index.html.

  • Eclipse: est également un IDE Java développé par la communauté open-source eclipse et peut être téléchargé depuis http://www.eclipse.org/.

Télécharger l'archive jackson

Téléchargez la dernière version du fichier jar Jackson à partir du référentiel Maven - Jackson . Dans ce didacticiel, jackson-core-2.8.9.jar, jackson-annotations-2.8.9.jar et jackson-databind-2.8.9.jar sont téléchargés et copiés dans le dossier C: \> jackson.

OS Nom de l'archive
les fenêtres jackson-xxx-2.8.9.jar
Linux jackson-xxx-2.8.9.jar
Mac jackson-xxx-2.8.9.jar

Définir l'environnement jackson

Met le jackson_HOMEvariable d'environnement pour pointer vers l'emplacement du répertoire de base où le jar Guava est stocké sur votre machine. En supposant que nous avons extrait jackson-core-2.8.9.jar, jackson-annotations-2.8.9.jar et jackson-databind-2.8.9.jar dans le dossier jackson sur divers systèmes d'exploitation comme suit.

OS Production
les fenêtres Définissez la variable d'environnement jackson_HOME sur C: \ jackson
Linux export jackson_HOME = / usr / local / jackson
Mac export jackson_HOME = / Bibliothèque / jackson

Définir la variable CLASSPATH

Met le CLASSPATHvariable d'environnement pour pointer vers l'emplacement du jar jackson. En supposant que nous avons stocké jackson-core-2.8.9.jar, jackson-annotations-2.8.9.jar et jackson-databind-2.8.9.jar dans le dossier jackson sur divers systèmes d'exploitation comme suit.

OS Production
les fenêtres Définissez la variable d'environnement CLASSPATH sur% CLASSPATH%;% jackson_HOME% \ jackson-core-2.8.9.jar;% jackson_HOME% \ jackson-databind-2.8.9.jar;% jackson_HOME% \ jackson-annotations-2.8.9. pot;.;
Linux export CLASSPATH = $ CLASSPATH:$jackson_HOME/jackson-core-2.8.9.jar:$jackson_HOME / jackson-databind-2.8.9.jar: $ jackson_HOME / jackson-annotations-2.8.9.jar :.
Mac export CLASSPATH = $ CLASSPATH:$jackson_HOME/jackson-core-2.8.9.jar:$jackson_HOME / jackson-databind-2.8.9.jar: $ jackson_HOME / jackson-annotations-2.8.9.jar :.

Avant d'entrer dans les détails de la bibliothèque jackson, voyons une application en action. Dans cet exemple, nous avons créé la classe Student. Nous allons créer une chaîne JSON avec les détails de l'étudiant et la désérialiser en objet étudiant, puis la sérialiser en une chaîne JSON.

Créez un fichier de classe Java nommé JacksonTester dans C:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

import java.io.IOException;

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[]){
   
      ObjectMapper mapper = new ObjectMapper();
      String jsonString = "{\"name\":\"Mahesh\", \"age\":21}";
      
      //map json to student
      try{
         Student student = mapper.readValue(jsonString, Student.class);
         
         System.out.println(student);
         
         jsonString = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(student);
         
         System.out.println(jsonString);
      }
      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

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Student [ name: Mahesh, age: 21 ]
{
  "name" : "Mahesh",
  "age" : 21
}

Étapes à retenir

Voici les étapes importantes à considérer ici.

Étape 1: Créez un objet ObjectMapper.

Créez un objet ObjectMapper. C'est un objet réutilisable.

ObjectMapper mapper = new ObjectMapper();

Étape 2: désérialiser JSON en objet.

Utilisez la méthode readValue () pour obtenir l'objet à partir du JSON. Passez la chaîne json / la source de la chaîne json et le type d'objet comme paramètre.

//Object to JSON Conversion
Student student = mapper.readValue(jsonString, Student.class);

Étape 3: sérialiser l'objet en JSON.

Utilisez la méthode writeValueAsString () pour obtenir la représentation sous forme de chaîne JSON d'un objet.

//Object to JSON Conversion		
jsonString = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(student);

ObjectMapper est la classe d'acteur principale de la bibliothèque Jackson. ObjectMapper classe ObjectMapper fournit des fonctionnalités de lecture et d'écriture JSON, soit vers et depuis des POJO de base (Plain Old Java Objects), soit vers et depuis un modèle d'arbre JSON à usage général (JsonNode), ainsi que des fonctionnalités associées pour effectuer des conversions. Il est également hautement personnalisable pour fonctionner à la fois avec différents styles de contenu JSON et pour prendre en charge des concepts d'objets plus avancés tels que le polymorphisme et l'identité d'objet. ObjectMapper sert également de fabrique pour les classes ObjectReader et ObjectWriter plus avancées.

Déclaration de classe

Voici la déclaration pour com.fasterxml.jackson.databind.ObjectMapper classe -

public class ObjectMapper
   extends ObjectCodec
      implements Versioned, Serializable

Classes imbriquées

S.No. Classe et description
1 static class ObjectMapper.DefaultTypeResolverBuilder

TypeResolverBuilder personnalisé qui fournit des générateurs de résolution de type utilisés avec ce que l'on appelle le «typage par défaut» (voir enableDefaultTyping () pour plus de détails).

2 static class ObjectMapper.DefaultTyping

Énumération utilisée avec enableDefaultTyping () pour spécifier le type de typage par défaut des types (classes) à utiliser.

Des champs

  • protected DeserializationConfig _deserializationConfig - Objet de configuration qui définit les paramètres globaux de base pour le processus de sérialisation.

  • protected DefaultDeserializationContext _deserializationContext- Objet de contexte Blueprint; stocké ici pour autoriser les sous-classes personnalisées.

  • protected InjectableValues _injectableValues - Fournisseur de valeurs à injecter dans les POJO désérialisés.

  • protected JsonFactory _jsonFactory - Usine utilisée pour créer des instances JsonParser et JsonGenerator si nécessaire.

  • protected SimpleMixInResolver _mixIns - Mappage qui définit comment appliquer les annotations de mix-in: key est le type des annotations supplémentaires reçues, et value est le type qui a des annotations à «mixer».

  • protected ConfigOverrides _propertyOverrides - Remplacements de configuration par type actuellement actifs, accessibles par type de propriété déclaré.

  • protected Set<Object> _registeredModuleTypes - Ensemble de types de modules (selon Module.getTypeId () qui ont été enregistrés; suivi de iff MapperFeature.IGNORE_DUPLICATE_MODULE_REGISTRATIONS est activé, de sorte que les appels d'enregistrement en double peuvent être ignorés (pour éviter d'ajouter les mêmes gestionnaires plusieurs fois, la plupart du temps).

  • protected ConcurrentHashMap<JavaType,JsonDeserializer<Object>> _rootDeserializers - Nous utiliserons une carte de niveau principal distincte pour garder une trace des désérialiseurs de niveau racine.

  • protected SerializationConfig _serializationConfig - Objet de configuration qui définit les paramètres globaux de base pour le processus de sérialisation.

  • protected SerializerFactory _serializerFactory - Usine de sérialiseurs utilisée pour construire des sérialiseurs.

  • protected DefaultSerializerProvider _serializerProvider - Objet qui gère l'accès aux sérialiseurs utilisés pour la sérialisation, y compris la mise en cache.

  • protected SubtypeResolver _subtypeResolver - Chose utilisée pour enregistrer les sous-types, les résoudre en super / sous-types selon les besoins.

  • protected TypeFactory _typeFactory- Usine spécifique utilisée pour créer des instances JavaType; nécessaire pour permettre aux modules d'ajouter une gestion de type plus personnalisée (principalement pour prendre en charge des types de langages JVM non Java).

  • protected static AnnotationIntrospector DEFAULT_ANNOTATION_INTROSPECTOR

  • protected static BaseSettings DEFAULT_BASE - Les paramètres de base contiennent les valeurs par défaut utilisées pour toutes les instances d'ObjectMapper.

  • protected static VisibilityChecker<?> STD_VISIBILITY_CHECKER

Constructeurs

S.No. Constructeur et description
1 ObjectMapper()

Le constructeur par défaut, qui construira le JsonFactory par défaut si nécessaire, utilise SerializerProvider comme SerializerProvider et BeanSerializerFactory comme SerializerFactory.

2 ObjectMapper(JsonFactory jf)

Construit une instance qui utilise JsonFactory spécifié pour construire les JsonParsers et / ou JsonGenerators nécessaires.

3 ObjectMapper(JsonFactory jf, SerializerProvider sp, DeserializerProvider dp)

Construit une instance qui utilise JsonFactory spécifié pour construire les JsonParsers et / ou JsonGenerators nécessaires, et utilise des fournisseurs donnés pour accéder aux sérialiseurs et désérialiseurs.

4 protected ObjectMapper(ObjectMapper src)

Copy-constructeur, principalement utilisé pour prendre en charge copy ().

Méthodes

Méthode d'assistance remplaçable utilisée pour construire SerializerProvider à utiliser pour la sérialisation. void addMixInAnnotations (classe <?> cible, classe <?> mixinSource) - obsolète. Depuis 2.5: remplacé par une forme courante de la méthode; addMixIn (Classe, Classe). protected DefaultDeserializationContext createDeserializationContext (JsonParser p, DeserializationConfig cfg) - Méthode d'assistance interne appelée pour créer une instance de DeserializationContext pour désérialiser une valeur racine unique. JsonSchema generateJsonSchema (Class <?> T) - Obsolète. Depuis 2.6, utilisez un générateur de schéma JSON externe (https://github.com/FasterXML/jackson-module-jsonSchema) (qui sous le capot appelle acceptJsonFormatVisitor (JavaType, JsonFormatVisitorWrapper)) void registerSubtypes (Class <?> ... classes) - Méthode d'enregistrement de la classe spécifiée en tant que sous-type, de sorte que la résolution basée sur le nom de type puisse lier les supertypes aux sous-types (au lieu d'utiliser des annotations). void setFilters (FilterProvider filterProvider) - Obsolète. Depuis 2.6, utilisez la méthode setFilterProvider (com.fasterxml.jackson.databind.ser.FilterProvider) à la place (autorise le chaînage) la méthode Factory pour la construction d'ObjectReader qui utilisera les détails d'échappement de caractères spécifiés pour la sortie.
1 protected void _checkInvalidCopy(Class<?> exp)

2 protected void _configAndWriteValue(JsonGenerator g, Object value) - Méthode appelée pour configurer le générateur si nécessaire, puis appeler la fonctionnalité d'écriture
3 protected Object _convert(Object fromValue, JavaType toValueType) - Implémentation de la conversion réelle: au lieu d'utiliser les méthodes de lecture et d'écriture existantes, une grande partie du code est incorporée.
4 protected JsonDeserializer<Object> _findRootDeserializer(DeserializationContext ctxt, JavaType valueType) - Méthode appelée pour localiser le désérialiseur pour la valeur de niveau racine transmise.
5 protected JsonToken _initForReading(JsonParser p) - Méthode appelée pour s'assurer que l'analyseur donné est prêt à lire le contenu pour la liaison de données.
6 protected ObjectReader _newReader(DeserializationConfig config) - Les sous-classes de méthodes d'usine doivent être remplacées pour produire des instances ObjectReader du sous-type approprié
sept protected ObjectReader _newReader(DeserializationConfig config, JavaType valueType, Object valueToUpdate, FormatSchema schema, InjectableValues injectableValues) - Les sous-classes de méthodes d'usine doivent être remplacées pour produire des instances ObjectReader du sous-type approprié
8 protected ObjectWriter _newWriter(SerializationConfig config) - Les sous-classes de méthodes d'usine doivent être remplacées pour produire des instances ObjectWriter du sous-type approprié
9 protected ObjectWriter _newWriter(SerializationConfig config, FormatSchema schema) - Les sous-classes de méthodes d'usine doivent être remplacées pour produire des instances ObjectWriter du sous-type approprié
dix protected ObjectWriter _newWriter(SerializationConfig config, JavaType rootType, PrettyPrinter pp) - Les sous-classes de méthode d'usine doivent être remplacées pour produire des instances ObjectWriter du sous-type approprié.
11 protected Object _readMapAndClose(JsonParser p0, JavaType valueType)
12 protected Object _readValue(DeserializationConfig cfg, JsonParser p, JavaType valueType) - Implémentation réelle de la lecture de valeur + opération de liaison.
13 protected DefaultSerializerProvider _serializerProvider(SerializationConfig config)
14 protected Object _unwrapAndDeserialize(JsonParser p, DeserializationContext ctxt, DeserializationConfig config, JavaType rootType, JsonDeserializer<Object> deser)
15 protected void _verifySchemaType(FormatSchema schema)
16 void acceptJsonFormatVisitor(Class<?> type, JsonFormatVisitorWrapper visitor) - Méthode de visite de la hiérarchie des types pour un type donné, en utilisant le visiteur spécifié.
17 void acceptJsonFormatVisitor(JavaType type, JsonFormatVisitorWrapper visitor) - Méthode de visite de la hiérarchie des types pour un type donné, en utilisant le visiteur spécifié.
18 ObjectMapper addHandler(DeserializationProblemHandler h) - Méthode d'ajout de DeserializationProblemHandler spécifié à utiliser pour gérer des problèmes spécifiques lors de la désérialisation.
19 ObjectMapper addMixIn(Class<?> target, Class<?> mixinSource) - Méthode à utiliser pour ajouter des annotations de mixage à utiliser pour augmenter la classe ou l'interface spécifiée.
20 boolean canDeserialize(JavaType type) - Méthode qui peut être appelée pour vérifier si le mappeur pense pouvoir désérialiser un objet d'un type donné.
21 boolean canDeserialize(JavaType type, AtomicReference<Throwable> cause) - Méthode similaire à canDeserialize (JavaType) mais qui peut renvoyer le Throwable réel qui a été lancé lors de la tentative de construction du sérialiseur: cela peut être utile pour déterminer quel est le problème réel.
22 boolean canSerialize(Class<?> type) - Méthode qui peut être appelée pour vérifier si le mappeur pense pouvoir sérialiser une instance d'une classe donnée.
23 boolean canSerialize(Class<?> type, AtomicReference<Throwable> cause) - Méthode similaire à canSerialize (Class) mais qui peut renvoyer le Throwable réel qui a été lancé lors de la tentative de construction du sérialiseur: cela peut être utile pour déterminer quel est le problème réel.
24 ObjectMapper clearProblemHandlers() - Méthode de suppression de toutes les instances DeserializationProblemHandlers enregistrées de ce mappeur.
25 MutableConfigOverride configOverride(Classlt;?> type) - Accesseur pour obtenir un objet de remplacement de configuration mutable pour un type donné, nécessaire pour ajouter ou modifier les remplacements par type appliqués aux propriétés d'un type donné.
26 ObjectMapper configure(DeserializationFeature f, boolean state) - Méthode de changement d'état d'une fonction de désérialisation on / off pour ce mappeur d'objets.
27 ObjectMapper configure(JsonGenerator.Feature f, boolean state) - Méthode de modification de l'état d'une fonction JsonGenerator on / off pour les instances de générateur créées par ce mappeur d'objets.
28 ObjectMapper configure(JsonParser.Feature f, boolean state) - Méthode de modification de l'état de JsonParser spécifié.Caractéristiques pour les instances d'analyseur créées par ce mappeur d'objets.
29 ObjectMapper configure(MapperFeature f, boolean state) - Méthode de modification de l'état d'une fonction de mappeur on / off pour cette instance de mappeur.
30 ObjectMapper configure(SerializationFeature f, boolean state) - Méthode de changement d'état d'une fonction de sérialisation marche / arrêt pour ce mappeur d'objets.
31 JavaType constructType(Type t) - Méthode pratique pour construire JavaType à partir d'un type donné (généralement java.lang.Class), mais sans contexte explicite.
32 <T> T convertValue(Object fromValue, Class<T> toValueType) - Méthode pratique pour effectuer une conversion en deux étapes à partir d'une valeur donnée, en une instance d'un type de valeur donné, si (mais seulement si!) Une conversion est nécessaire.
33 <T> T convertValue(Object fromValue, JavaType toValueType) - Voir convertValue (Object, Class)
34 <T> T convertValue(Object fromValue, TypeReference<?> toValueTypeRef) - Voir convertValue (Object, Class)
35 ObjectMapper copy() - Méthode de création d'une nouvelle instance d'ObjectMapper ayant la même configuration initiale que cette instance.
36 ArrayNode createArrayNode() - Remarque: le type de retour est co-variant, car l'abstraction ObjectCodec de base ne peut pas faire référence à des types de nœuds concrets (car elle fait partie du package principal, alors que les impls font partie du package mapper)
37 ObjectNode createObjectNode() - Remarque: le type de retour est co-variant, car l'abstraction ObjectCodec de base ne peut pas faire référence à des types de nœuds concrets (car elle fait partie du package principal, alors que les impls font partie du package mapper)
38 protected ClassIntrospector defaultClassIntrospector() - Méthode d'assistance remplaçable utilisée pour construire le ClassIntrospector par défaut à utiliser.
39 ObjectMapper disable(DeserializationFeature feature) - Méthode d'activation des fonctionnalités de DeserializationConfig spécifiées.
40 ObjectMapper disable(DeserializationFeature first, DeserializationFeature... f) - Méthode d'activation des fonctionnalités de DeserializationConfig spécifiées.
41 ObjectMapper disable(JsonGenerator.Feature... features) - Méthode de désactivation de JsonGenerator spécifié. Fonctionnalités pour les instances d'analyseur créées par ce mappeur d'objet.
42 ObjectMapper disable(JsonParser.Feature... features) - Méthode de désactivation de JsonParser spécifiée. Fonctionnalités pour les instances d'analyseur créées par ce mappeur d'objets.
43 ObjectMapper disable(MapperFeature... f) - Méthode d'activation des fonctionnalités de DeserializationConfig spécifiées.
44 ObjectMapper disable(SerializationFeature f) - Méthode d'activation des fonctionnalités de DeserializationConfig spécifiées.
45 ObjectMapper disable(SerializationFeature first, SerializationFeature... f) - Méthode d'activation des fonctionnalités de DeserializationConfig spécifiées.
46 ObjectMapper disableDefaultTyping()- Méthode de désactivation de l'inclusion automatique des informations de type; si tel est le cas, seuls les types explicitement annotés (ceux avec JsonTypeInfo) auront des informations de type incorporées supplémentaires.
47 ObjectMapper enable(DeserializationFeature feature) - Méthode d'activation des fonctionnalités de DeserializationConfig spécifiées.
48 ObjectMapper enable(DeserializationFeature first, DeserializationFeature... f) - Méthode d'activation des fonctionnalités de DeserializationConfig spécifiées.
49 ObjectMapper enable(JsonGenerator.Feature... features) - Méthode d'activation de JsonGenerator.Features spécifiées pour les instances d'analyseur créées par ce mappeur d'objets.
50 ObjectMapper enable(JsonParser.Feature... features) - Méthode d'activation de JsonParser.Features spécifiées pour les instances d'analyseur créées par ce mappeur d'objets.
51 ObjectMapper enable(MapperFeature... f) - Méthode d'activation des fonctionnalités MapperConfig spécifiées.
52 ObjectMapper enable(SerializationFeature f) - Méthode d'activation de la fonctionnalité DeserializationConfig spécifiée.
53 ObjectMapper enable(SerializationFeature first, SerializationFeature... f) - Méthode d'activation des fonctionnalités de DeserializationConfig spécifiées.
54 ObjectMapper enableDefaultTyping() - Méthode pratique qui équivaut à appeler
55 ObjectMapper enableDefaultTyping(ObjectMapper.DefaultTyping dti) - Méthode pratique qui équivaut à appeler
56 ObjectMapper enableDefaultTyping(ObjectMapper.DefaultTyping applicability, JsonTypeInfo.As includeAs) - Méthode d'activation de l'inclusion automatique des informations de type, nécessaire pour la désérialisation correcte des types polymorphes (sauf si les types ont été annotés avec JsonTypeInfo).
57 ObjectMapper enableDefaultTypingAsProperty(ObjectMapper.DefaultTyping applicability, String propertyName) - Méthode pour activer l'inclusion automatique des informations de type - nécessaire pour une désérialisation correcte des types polymorphes (sauf si les types ont été annotés avec JsonTypeInfo) - en utilisant le mécanisme d'inclusion "As.PROPERTY" et le nom de propriété spécifié à utiliser pour l'inclusion (la valeur par défaut étant "@ class "puisque les informations de type par défaut utilisent toujours le nom de classe comme identificateur de type)
58 ObjectMapper findAndRegisterModules() - Méthode pratique qui est fonctionnellement équivalente à: mapper.registerModules (mapper.findModules ());
59 Class<?> findMixInClassFor(Class<?> cls)
60 static List<Module> findModules() - Méthode de localisation des méthodes disponibles, à l'aide de la fonction JDK ServiceLoader, ainsi que du SPI fourni par le module.
61 static List<Module> findModules(ClassLoader classLoader) - Méthode de localisation des méthodes disponibles, à l'aide de la fonction JDK ServiceLoader, ainsi que du SPI fourni par le module.
62 DateFormat getDateFormat()
63 DeserializationConfig getDeserializationConfig() - Méthode qui renvoie l'objet DeserializationConfig par défaut partagé qui définit les paramètres de configuration pour la désérialisation.
64 DeserializationContext getDeserializationContext() - Méthode pour obtenir le DeserializationContext actuel.
65 JsonFactory getFactory() - Méthode qui peut être utilisée pour obtenir JsonFactory que ce mappeur utilise s'il a besoin de construire JsonParsers et / ou JsonGenerators.
66 InjectableValues getInjectableValues()
67 JsonFactory getJsonFactory()- Obsolète. Depuis la version 2.1: utilisez plutôt getFactory ()
68 JsonNodeFactory getNodeFactory() - Méthode qui peut être utilisée pour obtenir JsonNodeFactory que ce mappeur utilisera lors de la construction directe d'instances JsonNode racine pour les arbres.
69 PropertyNamingStrategy getPropertyNamingStrategy()
70 SerializationConfig getSerializationConfig() - Méthode qui renvoie l'objet SerializationConfig par défaut partagé qui définit les paramètres de configuration pour la sérialisation.
71 SerializerFactory getSerializerFactory() - Méthode pour obtenir SerializerFactory actuel.
72 SerializerProvider getSerializerProvider() - Accesseur pour l'instance "blueprint" (ou, factory), à partir de laquelle les instances sont créées en appelant DefaultSerializerProvider.createInstance (com.fasterxml.jackson.databind.SerializationConfig, com.fasterxml.jackson.databind.ser.SerializerFactory).
73 SerializerProvider getSerializerProviderInstance() - Accesseur pour construire et renvoyer une instance SerializerProvider qui peut être utilisée pour accéder aux sérialiseurs.
74 SubtypeResolver getSubtypeResolver() - Méthode d'accès au résolveur de sous-type utilisé.
75 TypeFactory getTypeFactory() - Accesseur pour obtenir l'instance TypeFactory actuellement configurée.
76 VisibilityChecker<?> getVisibilityChecker()- Méthode d'accès au vérificateur de visibilité actuellement configuré; objet utilisé pour déterminer si un élément de propriété donné (méthode, champ, constructeur) peut être détecté automatiquement ou non.
77 boolean isEnabled(DeserializationFeature f) - Méthode pour vérifier si une fonctionnalité spécifique à la désérialisation est activée.
78 boolean isEnabled(JsonFactory.Feature f) - Méthode de commodité, équivalente à:
79 boolean isEnabled(JsonGenerator.Feature f)
80 boolean isEnabled(JsonParser.Feature f)
81 boolean isEnabled(MapperFeature f) - Méthode pour vérifier si MapperFeature donné est activé.
82 boolean isEnabled(SerializationFeature f) - Méthode pour vérifier si une fonction spécifique à la sérialisation est activée.
83 int mixInCount()
84 ObjectReader reader() - Méthode d'usine pour construire ObjectReader avec les paramètres par défaut.
85 ObjectReader reader(Base64Variant defaultBase64) - Méthode d'usine pour construire ObjectReader qui utilisera la variante de codage Base64 spécifiée pour les données binaires codées en Base64.
86 ObjectReader reader(Class<?> type)- Obsolète. Depuis 2.5, utilisez à la place readerFor (Class)
87 ObjectReader reader(ContextAttributes attrs) - Méthode d'usine pour construire ObjectReader qui utilisera les attributs par défaut spécifiés.
88 ObjectReader reader(DeserializationFeature feature) - Méthode d'usine pour construire ObjectReader avec la fonctionnalité spécifiée activée (par rapport aux paramètres de cette instance de mappeur).
89 ObjectReader reader(DeserializationFeature first, DeserializationFeature... other) - Méthode d'usine pour construire ObjectReader avec les fonctionnalités spécifiées activées (par rapport aux paramètres de cette instance de mappeur).
90 ObjectReader reader(FormatSchema schema) - Méthode d'usine pour construire ObjectReader qui passera un objet de schéma spécifique à JsonParser utilisé pour lire le contenu.
91 ObjectReader reader(InjectableValues injectableValues) - Méthode d'usine pour construire ObjectReader qui utilisera les valeurs injectables spécifiées.
92 ObjectReader reader(JavaType type)- Obsolète. Depuis 2.5, utilisez à la place readerFor (JavaType)
93 ObjectReader reader(JsonNodeFactory f) - Méthode d'usine pour la construction d'ObjectReader qui utilisera JsonNodeFactory spécifié pour la construction d'arbres JSON.
94 ObjectReader reader(TypeReference<?> type)- Obsolète. Depuis 2.5, utilisez à la place readerFor (TypeReference)
95 ObjectReader readerFor(Class<?> type) - Méthode d'usine pour construire ObjectReader qui lira ou mettra à jour des instances du type spécifié
96 ObjectReader readerFor(JavaType type) - Méthode d'usine pour construire ObjectReader qui lira ou mettra à jour des instances du type spécifié
97 ObjectReader readerFor(TypeReference<?> type) - Méthode d'usine pour construire ObjectReader qui lira ou mettra à jour des instances du type spécifié
98 ObjectReader readerForUpdating(Object valueToUpdate) - Méthode d'usine pour construire ObjectReader qui mettra à jour un objet donné (généralement Bean, mais peut également être une collection ou une carte, mais PAS un tableau) avec des données JSON.
99 ObjectReader readerWithView(Class<?> view) - Méthode d'usine pour la construction d'ObjectReader qui désérialise les objets à l'aide de la vue JSON spécifiée (filtre).
100 JsonNode readTree(byte[] content) - Méthode pour désérialiser le contenu JSON sous forme d'arborescence exprimée à l'aide d'un ensemble d'instances JsonNode.
101 JsonNode readTree(File file) - Méthode pour désérialiser le contenu JSON sous forme d'arborescence exprimée à l'aide d'un ensemble d'instances JsonNode.
102 JsonNode readTree(InputStream in) - Méthode pour désérialiser le contenu JSON sous forme d'arborescence exprimée à l'aide d'un ensemble d'instances JsonNode.
103 <T extends TreeNode> T readTree(JsonParser p) - Méthode pour désérialiser le contenu JSON sous forme d'arborescence exprimée à l'aide d'un ensemble d'instances JsonNode.
104 JsonNode readTree(Reader r) - Méthode pour désérialiser le contenu JSON sous forme d'arborescence exprimée à l'aide d'un ensemble d'instances JsonNode.
105 JsonNode readTree(String content) - Méthode pour désérialiser le contenu JSON sous forme d'arborescence exprimée à l'aide d'un ensemble d'instances JsonNode.
106 JsonNode readTree(URL source) - Méthode pour désérialiser le contenu JSON sous forme d'arborescence exprimée à l'aide d'un ensemble d'instances JsonNode.
107 <T> T readValue(byte[] src, Class<T> valueType)
108 <T> T readValue(byte[] src, int offset, int len, Class<T> valueType)
109 <T> T readValue(byte[] src, int offset, int len, JavaType valueType)
110 <T> T readValue(byte[] src, int offset, int len, TypeReference valueTypeRef)
111 <T> T readValue(byte[] src, JavaType valueType)
112 <T> T readValue(byte[] src, TypeReference valueTypeRef)
113 <T> T readValue(DataInput src, Class<T> valueType)
114 <T> T readValue(DataInput src, JavaType valueType)
115 <T> T readValue(File src, Class<T> valueType) - Méthode pour désérialiser le contenu JSON d'un fichier donné dans un type Java donné.
116 <T> T readValue(File src, JavaType valueType) - Méthode pour désérialiser le contenu JSON d'un fichier donné dans un type Java donné.
117 <T> T readValue(File src, TypeReference valueTypeRef) - Méthode pour désérialiser le contenu JSON d'un fichier donné dans un type Java donné.
118 <T> T readValue(InputStream src, Class<T> valueType)
119 <T> T readValue(InputStream src, JavaType valueType)
120 <T> T readValue(InputStream src, TypeReference valueTypeRef)
121 <T> T readValue(JsonParser p, Class<T> valueType) - Method to deserialize JSON content into a non-container type (it can be an array type, however): typically a bean, array or a wrapper type (like Boolean).
122 <T> T readValue(JsonParser p, JavaType valueType) - Méthode surchargée de type sécurisé, essentiellement un alias pour readValue (JsonParser, Class).
123 <T> T readValue(JsonParser p, ResolvedType valueType) - Méthode pour désérialiser le contenu JSON en un type Java, dont la référence est passée en argument.
124 <T> T readValue(JsonParser p, TypeReference<?> valueTypeRef) - Méthode pour désérialiser le contenu JSON en un type Java, dont la référence est passée en argument.
125 <T> T readValue(Reader src, Class<T> valueType) -
1 <T> T readValue(Reader src, JavaType valueType)
126 <T> T readValue(Reader src, TypeReference valueTypeRef)
127 <T> T readValue(String content, Class<T> valueType) - Méthode pour désérialiser le contenu JSON à partir d'une chaîne de contenu JSON donnée.
128 <T> T readValue(String content, JavaType valueType) - Méthode pour désérialiser le contenu JSON à partir d'une chaîne de contenu JSON donnée.
129 <T> T readValue(String content, TypeReference valueTypeRef) - Méthode pour désérialiser le contenu JSON à partir d'une chaîne de contenu JSON donnée.
130 <T> T readValue(URL src, Class<T> valueType) - Méthode pour désérialiser le contenu JSON d'une ressource donnée dans un type Java donné.
131 <T> T readValue(URL src, JavaType valueType)
132 <T> T readValue(URL src, TypeReference valueTypeRef) - Méthode pour désérialiser le contenu JSON d'une ressource donnée dans un type Java donné.
133 <T> MappingIterator<T> readValues(JsonParser p, Class<T> valueType) - Méthode de confort, équivalente en fonction à:
134 <T> MappingIterator<T> readValues(JsonParser p, JavaType valueType) - Méthode de confort, équivalente en fonction à:
135 <T> MappingIterator<T> readValues(JsonParser p, ResolvedType valueType) - Méthode de confort, équivalente en fonction à:
136 <T> MappingIterator<T> readValues(JsonParser p, TypeReference<?>valueTypeRef) - Méthode de lecture de la séquence d'objets à partir du flux de l'analyseur.
137 ObjectMapper registerModule(Module module)- Méthode d'enregistrement d'un module pouvant étendre les fonctionnalités fournies par ce mappeur; par exemple, en ajoutant des fournisseurs pour les sérialiseurs et désérialiseurs personnalisés.
138 ObjectMapper registerModules(Iterable<Module> modules)- Méthode pratique pour enregistrer les modules spécifiés dans l'ordre; fonctionnellement équivalent à:
139 ObjectMapper registerModules(Module... modules)- Méthode pratique pour enregistrer les modules spécifiés dans l'ordre; fonctionnellement équivalent à:
140 void registerSubtypes(NamedType... types) - Méthode d'enregistrement de la classe spécifiée en tant que sous-type, de sorte que la résolution basée sur le nom de type puisse lier les supertypes à des sous-types (comme alternative à l'utilisation d'annotations).
141 ObjectMapper setAnnotationIntrospector(AnnotationIntrospector ai) - Méthode de définition d'AnnotationIntrospector utilisée par cette instance de mappeur pour la sérialisation et la désérialisation.
142 ObjectMapper setAnnotationIntrospectors(AnnotationIntrospector serializerAI, AnnotationIntrospector deserializerAI) - Méthode de modification des instances AnnotationIntrospector utilisée par cette instance de mappeur pour la sérialisation et la désérialisation, en les spécifiant séparément afin que différentes introspections puissent être utilisées pour différents aspects.
143 ObjectMapper setBase64Variant(Base64Variant v) - Méthode qui configurera Base64Variant par défaut que les sérialiseurs et désérialiseurs byte [] utiliseront.
144 ObjectMapper setConfig(DeserializationConfig config) - Méthode qui permet de remplacer l'objet DeserializationConfig sous-jacent.
145 ObjectMapper setConfig(SerializationConfig config) - Méthode qui permet de remplacer l'objet SerializationConfig sous-jacent, qui contient les paramètres de configuration spécifiques à la sérialisation.
146 ObjectMapper setDateFormat(DateFormat dateFormat) - Méthode de configuration du DateFormat par défaut à utiliser lors de la sérialisation des valeurs d'heure en tant que chaînes et de la désérialisation des chaînes JSON.
147 ObjectMapper setDefaultPrettyPrinter(PrettyPrinter pp) - Méthode de spécification de PrettyPrinter à utiliser lorsque "l'impression jolie par défaut" est activée (en activant SerializationFeature.INDENT_OUTPUT)
148 ObjectMapper setDefaultTyping(TypeResolverBuilder<?> typer) - Méthode pour activer l'inclusion automatique des informations de type, en utilisant un objet gestionnaire spécifié pour déterminer quels types cela affecte, ainsi que des détails sur la façon dont les informations sont incorporées.
149 ObjectMapper setFilterProvider(FilterProvider filterProvider) - Méthode de configuration de ce mappeur pour utiliser le FilterProvider spécifié pour mapper les ID de filtre aux instances de filtre réelles.
150 Object setHandlerInstantiator(HandlerInstantiator hi) - Méthode de configuration de HandlerInstantiator à utiliser pour créer des instances de gestionnaires (tels que des sérialiseurs, des désérialiseurs, des résolveurs d'id de type et de type), étant donné une classe.
151 ObjectMapper setInjectableValues(InjectableValues injectableValues) - Méthode de configuration des InjectableValues ​​qui permettait de trouver des valeurs à injecter.
152 ObjectMapper setLocale(Locale l) - Méthode de remplacement des paramètres régionaux par défaut à utiliser pour le formatage.
153 void setMixInAnnotations(Map<Class<?>,Class<?>> sourceMixins)- Obsolète. Depuis 2.5: remplacé par une forme courante de la méthode; setMixIns (java.util.Map <java.lang.Class <?>, java.lang.Class <? >>).
154 ObjectMapper setMixInResolver(ClassIntrospector.MixInResolver resolver) - Méthode qui peut être appelée pour spécifier un résolveur donné pour localiser les classes de mixage à utiliser, en remplaçant les mappages directement ajoutés.
155 ObjectMapper setMixIns(Map<Class<?>,Class<?>> sourceMixins) - Méthode à utiliser pour définir les annotations de mixage à utiliser pour augmenter les annotations que possèdent les classes traitables (sérialisables / désérialisables).
156 ObjectMapper setNodeFactory(JsonNodeFactory f) - Méthode de spécification de JsonNodeFactory à utiliser pour construire des nœuds d'arborescence au niveau racine (via la méthode createObjectNode ()
157 ObjectMapper setPropertyInclusion(JsonInclude.Value incl) - Méthode de définition de la stratégie d'inclusion de propriété POJO par défaut pour la sérialisation.
158 ObjectMapper setPropertyNamingStrategy(PropertyNamingStrategy s) - Méthode de définition de la stratégie de dénomination de propriété personnalisée à utiliser.
159 ObjectMapper setSerializationInclusion(JsonInclude.Include incl) - Méthode pratique, équivalente à l'appel:
160 ObjectMapper setSerializerFactory(SerializerFactory f) - Méthode de définition de SerializerFactory spécifique à utiliser pour la construction de sérialiseurs (bean).
161 ObjectMapper setSerializerProvider(DefaultSerializerProvider p) - Méthode de définition de l'instance SerializerProvider "blueprint" à utiliser comme base pour les instances de fournisseur réelles à utiliser pour gérer la mise en cache des instances JsonSerializer.
162 ObjectMapper setSubtypeResolver(SubtypeResolver str) - Méthode de définition du résolveur de sous-type personnalisé à utiliser.
163 ObjectMapper setTimeZone(TimeZone tz) - Méthode de remplacement de la zone horaire par défaut à utiliser pour le formatage.
164 ObjectMapper setTypeFactory(TypeFactory f) - Méthode qui peut être utilisée pour remplacer l'instance TypeFactory utilisée par ce mappeur.
165 ObjectMapper setVisibility(PropertyAccessor forMethod, JsonAutoDetect.Visibility visibility) - Méthode pratique qui permet de modifier la configuration des VisibilityCheckers sous-jacents, pour modifier les détails des types de propriétés détectés automatiquement.
166 ObjectMapper setVisibility(VisibilityChecker<?> vc) - Méthode de définition du VisibilityChecker actuellement configuré, objet utilisé pour déterminer si l'élément de propriété donné (méthode, champ, constructeur) peut être détecté automatiquement ou non.
167 void setVisibilityChecker(VisibilityChecker<?> vc)- Obsolète. Depuis 2.6, utilisez à la place setVisibility (VisibilityChecker).
168 JsonParser treeAsTokens(TreeNode n) - Méthode de construction d'un JsonParser à partir d'une représentation arborescente JSON.
169 <T> T treeToValue(TreeNode n, Class<T> valueType) - Méthode de conversion pratique qui liera les données que l'arborescence JSON contient dans un type de valeur spécifique (généralement un bean).
170 <T extends JsonNode> T valueToTree(Object fromValue)- Inverse de treeToValue (com.fasterxml.jackson.core.TreeNode, java.lang.Class <T>); étant donné une valeur (généralement bean), construira une représentation d'arbre JSON équivalente.
171 Version version() - Méthode qui retournera les informations de version stockées et lues à partir du fichier jar contenant cette classe.
172 ObjectWriter writer() - Méthode pratique pour construire ObjectWriter avec les paramètres par défaut.
173 ObjectWriter writer(Base64Variant defaultBase64) - Méthode d'usine pour construire ObjectWriter qui utilisera la variante de codage Base64 spécifiée pour les données binaires codées en Base64.
174 ObjectWriter writer(CharacterEscapes escapes) -
175 ObjectWriter writer(ContextAttributes attrs) - Méthode d'usine pour construire ObjectWriter qui utilisera les attributs par défaut spécifiés.
176 ObjectWriter writer(DateFormat df)- Méthode d'usine pour construire ObjectWriter qui sérialisera des objets en utilisant DateFormat spécifié; ou, si null est passé, à l'aide de l'horodatage (nombre 64 bits.
177 ObjectWriter writer(FilterProvider filterProvider) - Méthode d'usine pour construire ObjectWriter qui sérialisera les objets à l'aide du fournisseur de filtre spécifié.
178 ObjectWriter writer(FormatSchema schema) - Méthode d'usine pour construire ObjectWriter qui passera un objet de schéma spécifique à JsonGenerator utilisé pour écrire du contenu.
179 ObjectWriter writer(PrettyPrinter pp) - Méthode d'usine pour construire ObjectWriter qui sérialisera des objets en utilisant une jolie imprimante spécifiée pour l'indentation (ou si null, pas de jolie imprimante)
180 ObjectWriter writer(SerializationFeature feature) - Méthode d'usine pour construire ObjectWriter avec la fonctionnalité spécifiée activée (par rapport aux paramètres de cette instance de mappeur).
181 ObjectWriter writer(SerializationFeature first, SerializationFeature... other) - Méthode d'usine pour construire ObjectWriter avec les fonctionnalités spécifiées activées (par rapport aux paramètres de cette instance de mappeur).
182 ObjectWriter writerFor(Class<?> rootType) - Méthode d'usine pour la construction d'ObjectWriter qui sérialisera les objets en utilisant le type racine spécifié, au lieu du type d'exécution réel de valeur.
183 ObjectWriter writerFor(JavaType rootType) - Méthode d'usine pour la construction d'ObjectWriter qui sérialisera les objets en utilisant le type racine spécifié, au lieu du type d'exécution réel de valeur.
184 ObjectWriter writerFor(TypeReference<?> rootType) - Méthode d'usine pour la construction d'ObjectWriter qui sérialisera les objets en utilisant le type racine spécifié, au lieu du type d'exécution réel de valeur.
185 ObjectWriter writerWithDefaultPrettyPrinter() - Méthode d'usine pour construire ObjectWriter qui sérialisera des objets en utilisant la jolie imprimante par défaut pour l'indentation.
186 ObjectWriter writerWithType(Class<?> rootType)- Obsolète. Depuis la version 2.5, utilisez plutôt writerFor (Class).
187 ObjectWriter writerWithType(JavaType rootType)- Obsolète. Depuis la version 2.5, utilisez plutôt writerFor (JavaType).
188 ObjectWriter writerWithType(TypeReference<?> rootType)- Obsolète. Depuis la version 2.5, utilisez plutôt writerFor (TypeReference).
189 ObjectWriter writerWithView(Class<?> serializationView) - Méthode d'usine pour la construction d'ObjectWriter qui sérialisera les objets en utilisant la vue JSON spécifiée (filtre).
190 void writeTree(JsonGenerator jgen, JsonNode rootNode) - Méthode de sérialisation de l'arbre JSON donné, à l'aide du générateur fourni.
191 void writeTree(JsonGenerator jgen, TreeNode rootNode)
192 void writeValue(DataOutput out, Object value)
193 void writeValue(File resultFile, Object value) - Méthode qui peut être utilisée pour sérialiser toute valeur Java en tant que sortie JSON, écrite dans le fichier fourni.
194 void writeValue(JsonGenerator g, Object value) - Méthode qui peut être utilisée pour sérialiser toute valeur Java en tant que sortie JSON, en utilisant JsonGenerator fourni.
195 void writeValue(OutputStream out, Object value) - Méthode qui peut être utilisée pour sérialiser n'importe quelle valeur Java en tant que sortie JSON, en utilisant le flux de sortie fourni (en utilisant le codage JsonEncoding.UTF8).
196 void writeValue(Writer w, Object value) - Méthode qui peut être utilisée pour sérialiser toute valeur Java en tant que sortie JSON, à l'aide de Writer fourni.
197 byte[] writeValueAsBytes(Object value) - Méthode qui peut être utilisée pour sérialiser toute valeur Java sous forme de tableau d'octets.
198 String writeValueAsString(Object value) - Méthode qui peut être utilisée pour sérialiser toute valeur Java en tant que chaîne.

Méthodes héritées

Cette classe hérite des méthodes des classes suivantes:

  • java.lang.Object

Exemple d'ObjectMapper

Créez le programme Java suivant en utilisant n'importe quel éditeur de votre choix dans say C:/> Jackson_WORKSPACE

Fichier: JacksonTester.java

import java.io.IOException;

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[]){
   
      ObjectMapper mapper = new ObjectMapper();
      String jsonString = "{\"name\":\"Mahesh\", \"age\":21}";
      
      //map json to student
      try{
         Student student = mapper.readValue(jsonString, Student.class);
         
         System.out.println(student);
         
         jsonString = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(student);
         
         System.out.println(jsonString);
      }
      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

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Student [ name: Mahesh, age: 21 ]
{
  "name" : "Mahesh",
  "age" : 21
}

Sérialisation d'objets

sérialisons un objet java dans un fichier json, puis lisons ce fichier json pour récupérer l'objet. Dans cet exemple, nous avons créé la classe Student. Nous allons créer un fichier student.json qui aura une représentation json de l'objet Student.

Créez un fichier de classe Java nommé JacksonTester dans C:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

import java.io.File;
import java.io.IOException;

import com.fasterxml.jackson.core.JsonGenerationException;
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 {
         Student student = new Student();
         student.setAge(10);
         student.setName("Mahesh");
         tester.writeJSON(student);

         Student student1 = tester.readJSON();
         System.out.println(student1);

      } catch (JsonParseException e) {
         e.printStackTrace();
      } catch (JsonMappingException e) {
         e.printStackTrace();
      } catch (IOException e) {
         e.printStackTrace();
      }
   }

   private void writeJSON(Student student) throws JsonGenerationException, JsonMappingException, IOException{
      ObjectMapper mapper = new ObjectMapper();	
      mapper.writeValue(new File("student.json"), student);
   }

   private Student readJSON() throws JsonParseException, JsonMappingException, IOException{
      ObjectMapper mapper = new ObjectMapper();
      Student student = mapper.readValue(new File("student.json"), 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+ " ]";
   }	
}

Verify the result

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Student [ name: Mahesh, age: 10 ]

Liaison de données

L'API de liaison de données est utilisée pour convertir JSON vers et depuis POJO (Plain Old Java Object) à l'aide d'un accesseur de propriété ou à l'aide d'annotations. Il est de deux types.

  • Simple Data Binding - Convertit JSON vers et depuis Java Maps, Lists, Strings, Numbers, Booleans et objets null.

  • Full Data Binding - Convertit JSON vers et depuis n'importe quel type JAVA.

ObjectMapper lit / écrit JSON pour les deux types de liaisons de données. La liaison de données est le moyen le plus pratique et est analogue au parer JAXB pour XML.

Liaison de données simple

La liaison de données simple fait référence au mappage de JSON aux types de données JAVA Core. Le tableau suivant illustre la relation entre les types JSON et les types Java.

Sr. No. Type JSON Type Java
1 objet LinkedHashMap <Chaîne, Objet>
2 tableau ArrayList <Objet>
3 chaîne Chaîne
4 numéro complet Entier, Long ou BigInteger
5 nombre fractionnaire Double / BigDecimal
6 vrai | faux Booléen
sept nul nul

Voyons la liaison de données simple en action. Ici, nous allons mapper les types de base JAVA directement vers JSON et vice versa.

Créez un fichier de classe Java nommé JacksonTester dans C:\>Jackson_WORKSPACE.

Fichier: 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

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

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

Liaison complète des données

La liaison de données complète fait référence au mappage de JSON à n'importe quel objet JAVA.

//Create an ObjectMapper instance
ObjectMapper mapper = new ObjectMapper();	
//map JSON content to Student object
Student student = mapper.readValue(new File("student.json"), Student.class);
//map Student object to JSON content
mapper.writeValue(new File("student.json"), student);

Voyons la liaison de données simple en action. Ici, nous allons mapper l'objet JAVA directement à JSON et vice versa.

Créez un fichier de classe Java nommé JacksonTester dans C:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

import java.io.File;
import java.io.IOException;

import com.fasterxml.jackson.core.JsonGenerationException;
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 {
         Student student = new Student();
         student.setAge(10);
         student.setName("Mahesh");
         tester.writeJSON(student);

         Student student1 = tester.readJSON();
         System.out.println(student1);

      } catch (JsonParseException e) {
         e.printStackTrace();
      } catch (JsonMappingException e) {
         e.printStackTrace();
      } catch (IOException e) {
         e.printStackTrace();
      }
   }

   private void writeJSON(Student student) throws JsonGenerationException, JsonMappingException, IOException{
      ObjectMapper mapper = new ObjectMapper();	
      mapper.writeValue(new File("student.json"), student);
   }

   private Student readJSON() throws JsonParseException, JsonMappingException, IOException{
      ObjectMapper mapper = new ObjectMapper();
      Student student = mapper.readValue(new File("student.json"), 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+ " ]";
   }	
}

Verify the result

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Student [ name: Mahesh, age: 10 ]

Liaison de données avec des génériques

Dans la liaison de données simple, nous avons utilisé la classe Map qui utilise String comme clé et Object comme objet valeur. Au lieu de cela, nous pouvons avoir un objet java concret et le type cast pour être utilisé dans la liaison JSON.

Prenons l'exemple suivant avec une classe UserData, une classe contenant des données spécifiques à l'utilisateur.

Créez un fichier de classe Java nommé JacksonTester dans C:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

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

import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.core.type.TypeReference;
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, UserData> userDataMap = new HashMap<String, UserData>();
            UserData studentData = new UserData(); 
            int[] marks = {1,2,3};

            Student student = new Student();
            student.setAge(10);
            student.setName("Mahesh");
            // JAVA Object
            studentData.setStudent(student);
            // JAVA String
            studentData.setName("Mahesh Kumar");
            // JAVA Boolean
            studentData.setVerified(Boolean.FALSE);
            // Array
            studentData.setMarks(marks);
            TypeReference ref = new TypeReference<Map<String,UserData>>() { };
            userDataMap.put("studentData1", studentData);
            mapper.writeValue(new File("student.json"), userDataMap);
            //{
            //   "studentData1":
            //	 {
            //		"student":
            //		{
            //			"name":"Mahesh",
            //			"age":10
            //      },
            //      "name":"Mahesh Kumar",
            //      "verified":false,
            //      "marks":[1,2,3]
            //   }
            //}
            userDataMap = mapper.readValue(new File("student.json"), ref);

            System.out.println(userDataMap.get("studentData1").getStudent());
            System.out.println(userDataMap.get("studentData1").getName());
            System.out.println(userDataMap.get("studentData1").getVerified());
            System.out.println(Arrays.toString(userDataMap.get("studentData1").getMarks()));
      } 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+ " ]";
   }	
}

class UserData {
   private Student student;
   private String name;
   private Boolean verified;
   private int[] marks;

   public UserData(){}

   public Student getStudent() {
      return student;
   }
   public void setStudent(Student student) {
      this.student = student;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name;
   }
   public Boolean getVerified() {
      return verified;
   }
   public void setVerified(Boolean verified) {
      this.verified = verified;
   }
   public int[] getMarks() {
      return marks;
   }
   public void setMarks(int[] marks) {
      this.marks = marks;
   }		
}

Verify the result

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Student [ name: Mahesh, age: 10 ]
Mahesh Kumar
false
[1, 2, 3]

Modèle d'arbre

Le modèle d'arbre prépare une représentation arborescente en mémoire du document JSON. ObjectMapper crée l'arborescence des nœuds JsonNode. C'est l'approche la plus flexible. Il est analogue à l'analyseur DOM pour XML.

Créer une arborescence à partir de JSON

ObjectMapper fournit un pointeur vers le nœud racine de l'arborescence après avoir lu le JSON. Le nœud racine peut être utilisé pour parcourir l'arborescence complète. Considérez l'extrait de code suivant pour obtenir le nœud racine d'une chaîne JSON fournie.

//Create an ObjectMapper instance
ObjectMapper mapper = new ObjectMapper();	
String jsonString = "{\"name\":\"Mahesh Kumar\", \"age\":21,\"verified\":false,\"marks\": [100,90,85]}";
//create tree from JSON
JsonNode rootNode = mapper.readTree(jsonString);

Modèle d'arbre de déplacement

Obtenez chaque nœud en utilisant le chemin relatif vers le nœud racine tout en parcourant l'arborescence et traitez les données. Considérez l'extrait de code suivant traversant l'arborescence fournie par le nœud racine.

JsonNode nameNode = rootNode.path("name");
System.out.println("Name: "+ nameNode.textValue());
 
JsonNode marksNode = rootNode.path("marks");
Iterator<JsonNode> iterator = marksNode.elements();

Exemple

Créez un fichier de classe Java nommé JacksonTester dans C:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

import java.io.IOException;
import java.util.Iterator;

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

public class JacksonTester {
   public static void main(String args[]){

      try {
         ObjectMapper mapper = new ObjectMapper();
         String jsonString = "{\"name\":\"Mahesh Kumar\",  \"age\":21,\"verified\":false,\"marks\": [100,90,85]}";
         JsonNode rootNode = mapper.readTree(jsonString);

         JsonNode nameNode = rootNode.path("name");
         System.out.println("Name: "+ nameNode.textValue());

         JsonNode ageNode = rootNode.path("age");
         System.out.println("Age: " + ageNode.intValue());

         JsonNode verifiedNode = rootNode.path("verified");
         System.out.println("Verified: " + (verifiedNode.booleanValue() ? "Yes":"No"));

         JsonNode marksNode = rootNode.path("marks");
         Iterator<JsonNode> iterator = marksNode.elements();
         System.out.print("Marks: [ ");

         while (iterator.hasNext()) {
            JsonNode marks = iterator.next();
            System.out.print(marks.intValue() + " "); 
         }

         System.out.println("]");
      }
      catch (JsonParseException e) { e.printStackTrace(); }
      catch (JsonMappingException e) { e.printStackTrace(); }
      catch (IOException e) { e.printStackTrace(); }
   }
}

Verify the result

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Name: Mahesh Kumar
Age: 21
Verified: No
Marks: [ 100 90 85 ]

Arbre en JSON

Dans cet exemple, nous avons créé une arborescence à l'aide de JsonNode et l'avons écrite dans un fichier json et relue.

Créez un fichier de classe Java nommé JacksonTester dans C:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

import java.io.IOException;
import java.util.Iterator;

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

public class JacksonTester {
   public static void main(String args[]){

      try {
         ObjectMapper mapper = new ObjectMapper();
         String jsonString = "{\"name\":\"Mahesh Kumar\",  \"age\":21,\"verified\":false,\"marks\": [100,90,85]}";
         JsonNode rootNode = mapper.readTree(jsonString);

         JsonNode nameNode = rootNode.path("name");
         System.out.println("Name: "+ nameNode.textValue());

         JsonNode ageNode = rootNode.path("age");
         System.out.println("Age: " + ageNode.intValue());

         JsonNode verifiedNode = rootNode.path("verified");
         System.out.println("Verified: " + (verifiedNode.booleanValue() ? "Yes":"No"));

         JsonNode marksNode = rootNode.path("marks");
         Iterator<JsonNode> iterator = marksNode.elements();
         System.out.print("Marks: [ ");

         while (iterator.hasNext()) {
            JsonNode marks = iterator.next();
            System.out.print(marks.intValue() + " "); 
         }

         System.out.println("]");
      }
      catch (JsonParseException e) { e.printStackTrace(); }
      catch (JsonMappingException e) { e.printStackTrace(); }
      catch (IOException e) { e.printStackTrace(); }
   }
}

Verify the result

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Name: Mahesh Kumar
Age: 21
Verified: No
Marks: [ 100 90 85 ]

Arborescence vers objets Java

Dans cet exemple, nous avons créé une arborescence à l'aide de JsonNode et l'écrivons dans un fichier json, lisons l'arborescence, puis la convertissons en objet Student.

Créez un fichier de classe Java nommé JacksonTester dans C:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

import java.io.File;
import java.io.IOException;
import java.util.Iterator;

import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.ArrayNode;
import com.fasterxml.jackson.databind.node.ObjectNode;

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

         JsonNode rootNode = mapper.createObjectNode();
         JsonNode marksNode = mapper.createArrayNode();
         ((ArrayNode)marksNode).add(100);
         ((ArrayNode)marksNode).add(90);
         ((ArrayNode)marksNode).add(85);
         ((ObjectNode) rootNode).put("name", "Mahesh Kumar");
         ((ObjectNode) rootNode).put("age", 21);
         ((ObjectNode) rootNode).put("verified", false);
         ((ObjectNode) rootNode).put("marks",marksNode);

         mapper.writeValue(new File("student.json"), rootNode);

         rootNode = mapper.readTree(new File("student.json"));

         Student student = mapper.treeToValue(rootNode, Student.class);

         System.out.println("Name: "+ student.getName());
         System.out.println("Age: " + student.getAge());
         System.out.println("Verified: " + (student.isVerified() ? "Yes":"No"));
         System.out.println("Marks: "+Arrays.toString(student.getMarks()));
      } catch (JsonParseException e) {
         e.printStackTrace();
      } catch (JsonMappingException e) {
         e.printStackTrace();
      } catch (IOException e) {
         e.printStackTrace();
      }
   }
}
class Student {
   String name;
   int age;
   boolean verified;
   int[] marks;
   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 boolean isVerified() {
      return verified;
   }
   public void setVerified(boolean verified) {
      this.verified = verified;
   }
   public int[] getMarks() {
      return marks;
   }
   public void setMarks(int[] marks) {
      this.marks = marks;
   }
}

Verify the result

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Name: Mahesh Kumar
Age: 21
Verified: No
Marks: [ 100 90 85 ]

API de streaming

L'API Streaming lit et écrit le contenu JSON en tant qu'événements discrets. JsonParser lit les données tandis que JsonGenerator écrit les données. C'est l'approche la plus puissante parmi les trois, la plus faible surcharge et la plus rapide dans les opérations de lecture / écriture. C'est l'analyseur Analogus to Stax pour XML.

Dans cet article, nous présenterons l'utilisation des API de streaming Jackson pour lire et écrire des données JSON. L'API de streaming fonctionne avec le concept de jeton et tous les détails de Json doivent être traités avec soin. Voici deux classes que nous utiliserons dans les exemples:

  • JsonGenerator - Ecrire dans la chaîne JSON.

  • JsonParser - Analyser la chaîne JSON.

Ecrire JSON à l'aide de JsonGenerator

L'utilisation de JsonGenerator est assez simple. Commencez par créer le JsonGenerator à l'aide de la méthode JsonFactory.createJsonGenerator () et utilisez ses méthodes write *** () pour écrire chaque valeur json.

JsonFactory jsonFactory = new JsonFactory();
JsonGenerator jsonGenerator = jsonFactory.createGenerator(new File(
   "student.json"), JsonEncoding.UTF8);
// {
jsonGenerator.writeStartObject();
// "name" : "Mahesh Kumar"
jsonGenerator.writeStringField("name", "Mahesh Kumar");

Voyons JsonGenerator en action. Créez un fichier de classe Java nommé JacksonTester dansC:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

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

import com.fasterxml.jackson.core.JsonEncoding;
import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonGenerator;
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[]){

      try {         
         JsonFactory jsonFactory = new JsonFactory();
         JsonGenerator jsonGenerator = jsonFactory.createGenerator(new File("student.json"), JsonEncoding.UTF8);

         jsonGenerator.writeStartObject();

         // "name" : "Mahesh Kumar"
         jsonGenerator.writeStringField("name", "Mahesh Kumar"); 

         // "age" : 21
         jsonGenerator.writeNumberField("age", 21);

         // "verified" : false
         jsonGenerator.writeBooleanField("verified", false);

         // "marks" : [100, 90, 85]
         jsonGenerator.writeFieldName("marks"); 

         // [
         jsonGenerator.writeStartArray(); 
         // 100, 90, 85
         jsonGenerator.writeNumber(100); 
         jsonGenerator.writeNumber(90); 
         jsonGenerator.writeNumber(85); 
         // ]

         jsonGenerator.writeEndArray(); 

         jsonGenerator.writeEndObject(); 
         jsonGenerator.close();        

         //result student.json
         //{ 
         //   "name":"Mahesh Kumar",
         //   "age":21,
         //   "verified":false,
         //   "marks":[100,90,85]
         //}

         ObjectMapper mapper = new ObjectMapper();
         Map<String,Object> dataMap = mapper.readValue(new File("student.json"), Map.class);

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

Verify the result

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Mahesh Kumar
21
false
[100, 90, 85]

Lire JSON à l'aide de JsonParser

L'utilisation de JsonParser est encore une fois assez simple. Commencez par créer le JsonParser en utilisant la méthode JsonFactory.createJsonParser () et utilisez ses méthodes nextToken () pour lire chaque chaîne json en tant que jeton. Vérifiez chaque jeton et procédez en conséquence

JsonFactory jasonFactory = new JsonFactory();
JsonParser jsonParser = jasonFactory.createJsonParser(new File("student.json"));
while (jsonParser.nextToken() != JsonToken.END_OBJECT) {
   //get the current token
   String fieldname = jsonParser.getCurrentName();
   if ("name".equals(fieldname)) {
      //move to next token
      jsonParser.nextToken();
      System.out.println(jsonParser.getText());        	 
   }
}

Voyons JsonParser en action. Créez un fichier de classe Java nommé JacksonTester dansC:\>Jackson_WORKSPACE.

Fichier: JacksonTester.java

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

import com.fasterxml.jackson.core.JsonEncoding;
import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonGenerator;
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 {        	
         JsonFactory jsonFactory = new JsonFactory();

         JsonGenerator jsonGenerator = jsonFactory.createGenerator(new File(
            "student.json"), JsonEncoding.UTF8);
         jsonGenerator.writeStartObject();
         jsonGenerator.writeStringField("name", "Mahesh Kumar"); 
         jsonGenerator.writeNumberField("age", 21);
         jsonGenerator.writeBooleanField("verified", false); 
         jsonGenerator.writeFieldName("marks"); 
         jsonGenerator.writeStartArray(); // [
         jsonGenerator.writeNumber(100); 
         jsonGenerator.writeNumber(90); 
         jsonGenerator.writeNumber(85); 
         jsonGenerator.writeEndArray(); 
         jsonGenerator.writeEndObject(); 
         jsonGenerator.close();       	 

         //result student.json
         //{ 
         //   "name":"Mahesh Kumar",
         //   "age":21,
         //   "verified":false,
         //   "marks":[100,90,85]
         //}

         JsonParser jsonParser = jsonFactory.createParser(new File("student.json"));
         while (jsonParser.nextToken() != JsonToken.END_OBJECT) {
            //get the current token
            String fieldname = jsonParser.getCurrentName();
            if ("name".equals(fieldname)) {
               //move to next token
               jsonParser.nextToken();
               System.out.println(jsonParser.getText());        	 
            }
            if("age".equals(fieldname)){
               //move to next token
               jsonParser.nextToken();
               System.out.println(jsonParser.getNumberValue());        	 
            }
            if("verified".equals(fieldname)){
               //move to next token
               jsonParser.nextToken();
               System.out.println(jsonParser.getBooleanValue());        	 
            }
            if("marks".equals(fieldname)){
               //move to [ 
               jsonParser.nextToken();
               // loop till token equal to "]"
               while (jsonParser.nextToken() != JsonToken.END_ARRAY) {
                  System.out.println(jsonParser.getNumberValue()); 
               }
            }
         }
      } catch (JsonParseException e) {
         e.printStackTrace();
      } catch (JsonMappingException e) {
         e.printStackTrace();
      } catch (IOException e) {
         e.printStackTrace();
      }
   }
}

Verify the result

Compilez les classes en utilisant javac compilateur comme suit:

C:\Jackson_WORKSPACE>javac JacksonTester.java

Exécutez maintenant le jacksonTester pour voir le résultat:

C:\Jackson_WORKSPACE>java JacksonTester

Vérifiez la sortie

Mahesh Kumar
21
false
[100, 90, 85]

Classe JsonGenerator

introduction

JsonParser est la classe de base pour définir l'API publique pour la lecture du contenu Json. Les instances sont créées à l'aide des méthodes d'usine d'une instance JsonFactory.

Déclaration de classe

Voici la déclaration pour org.codehaus.jackson.JsonParser classe:

public abstract class JsonParser
   extends Object
      implements Closeable, Versioned

Classes imbriquées

SN Classe et description
1 static class JsonParser.Feature
Énumération qui définit toutes les fonctionnalités basculantes pour les analyseurs.
2 static class JsonParser.NumberType
Énumération des types "natifs" (optimaux) possibles qui peuvent être utilisés pour les nombres.

Des champs

  • protected PrettyPrinter _cfgPrettyPrinter - Objet qui gère la jolie impression (généralement un espace blanc supplémentaire pour rendre les résultats plus lisibles par l'homme) lors de la sortie.

  • protected JsonToken _currToken - Dernier jeton récupéré via nextToken (), le cas échéant.

  • protected int _features - Indicateur de bits composé de bits indiquant les fonctionnalités JsonParser.Features activées.

  • protected JsonToken _lastClearedToken - Dernier jeton effacé, le cas échéant: c'est-à-dire la valeur qui était en vigueur lorsque clearCurrentToken () a été appelé.

Constructeurs

SN Constructeur et description
1 protected JsonParser()
Constructeur par défaut
2 protected JsonParser(int features)

Méthodes de classe

SN Méthode et description
1 protected void _reportError(String msg) - Méthode d'assistance utilisée pour construire et lancer JsonGenerationException avec un message de base donné.
2 protected void _reportUnsupportedOperation()
3 protected void _throwInternal()
4 protected void _writeSimpleObject(Object value)- Méthode d'assistance pour essayer d'appeler la méthode d'écriture appropriée pour un objet non typé donné.
5 boolean canOmitFields() - Méthode d'introspection à appeler pour vérifier s'il est correct d'omettre l'écriture des champs Object ou non.
6 boolean canUseSchema(FormatSchema schema) - Méthode qui peut être utilisée pour vérifier que le schéma donné peut être utilisé avec ce générateur (en utilisant setSchema (com.fasterxml.jackson.core.FormatSchema)).
sept boolean canWriteBinaryNatively()- Méthode d'introspection qui peut être appelée pour voir si le format de données sous-jacent prend en charge les données binaires "natives"; c'est-à-dire une sortie efficace de contenu binaire sans encodage.
8 boolean canWriteObjectId() - Méthode d'introspection qui peut être appelée pour voir si le format de données sous-jacent prend en charge un certain type d'ID d'objet de manière native (beaucoup ne le font pas; par exemple, JSON ne le fait pas).
9 boolean canWriteTypeId() - Méthode d'introspection qui peut être appelée pour voir si le format de données sous-jacent prend en charge un certain type d'identificateurs de type nativement (beaucoup ne le font pas; par exemple, JSON ne le fait pas).
dix abstract void close() - Méthode appelée pour fermer ce générateur, afin qu'aucun contenu ne puisse plus être écrit.
11 JsonGenerator configure(JsonGenerator.Feature f, boolean state) - Méthode d'activation ou de désactivation de la fonctionnalité spécifiée: vérifiez JsonGenerator.Feature pour la liste des fonctionnalités disponibles.
12 void copyCurrentEvent(JsonParser jp) - Méthode de copie du contenu de l'événement en cours vers lequel pointe l'instance de l'analyseur donné.
13 void copyCurrentStructure(JsonParser jp) - Méthode de copie du contenu de l'événement courant et des événements suivants sur lesquels il englobe l'instance de l'analyseur donné.
14 abstract JsonGenerator disable(JsonGenerator.Feature f) - Method for disabling specified features (check JsonGenerator.Feature for list of features)
15 abstract JsonGenerator enable(JsonGenerator.Feature f) - Méthode d'activation des fonctionnalités d'analyseur spécifiées: vérifiez JsonGenerator.Feature pour la liste des fonctionnalités disponibles.
16 abstract void flush() - Méthode appelée pour vider tout contenu mis en mémoire tampon sur la cible sous-jacente (flux de sortie, rédacteur), et pour vider également la cible elle-même.
17 CharacterEscapes getCharacterEscapes() - Méthode d'accès aux échappements personnalisés utilisée par l'usine pour les JsonGenerators qu'elle crée.
18 abstract ObjectCodec getCodec() - Méthode d'accès à l'objet utilisé pour écrire l'objet Java en tant que contenu Json (à l'aide de la méthode writeObject (java.lang.Object)).
19 abstract int getFeatureMask() - Méthode d'accès en bloc pour obtenir l'état de toutes les fonctionnalités JsonGenerator.Features standard.
20 int getHighestEscapedChar() - Méthode d'accesseur pour tester quel est le caractère non échappé le plus élevé configuré pour ce générateur.
21 abstract JsonStreamContext getOutputContext()
22 Object getOutputTarget()- Méthode qui peut être utilisée pour accéder à l'objet qui est utilisé comme cible pour la sortie générée; il s'agit généralement de OutputStream ou Writer, selon le générateur avec lequel il a été construit.
23 PrettyPrinter getPrettyPrinter()- Accesseur pour vérifier si ce générateur a une PrettyPrinter configurée; le renvoie si tel est le cas, nul si aucun n'est configuré.
24 FormatSchema getSchema() - Méthode d'accès au schéma que cet analyseur utilise, le cas échéant.
25 abstract boolean isClosed() - Méthode pouvant être appelée pour déterminer si ce générateur est fermé ou non.
26 abstract boolean isEnabled(JsonGenerator.Feature f) - Méthode pour vérifier si une fonction donnée est activée.
27 JsonGenerator setCharacterEscapes(CharacterEscapes esc)-Méthode de définition des échappements personnalisés en usine pour les JsonGenerators qu'elle crée.
28 abstract JsonGenerator setCodec(ObjectCodec oc)- Méthode qui peut être appelée pour définir ou réinitialiser l'objet à utiliser pour écrire des objets Java en tant que JsonContent (en utilisant la méthode writeObject (java.lang.Object)).
29 abstract JsonGenerator setFeatureMask(int mask)-Méthode de jeu en bloc pour (re) régler les états de tous les JsonGenerator standard.
30 JsonGenerator setHighestNonEscapedChar(int charCode) - Method that can be called to request that generator escapes all character codes above specified code point (if positive value); or, to not escape any characters except for ones that must be escaped for the data format (if -1).
31 JsonGenerator setPrettyPrinter(PrettyPrinter pp) - Méthode de définition d'une jolie imprimante personnalisée, généralement utilisée pour ajouter une indentation pour une meilleure lisibilité humaine.
32 JsonGenerator setRootValueSeparator(SerializableString sep) - Méthode qui permet de remplacer la chaîne utilisée pour séparer les valeurs JSON au niveau racine (la valeur par défaut est un caractère d'espace unique)
33 void setSchema(FormatSchema schema) - Méthode à appeler pour que ce générateur utilise le schéma spécifié.
33 abstract JsonGenerator useDefaultPrettyPrinter()- Méthode pratique pour activer la jolie impression à l'aide de la jolie imprimante par défaut (DefaultPrettyPrinter).
34 abstract Version version()- Accesseur pour trouver la version du bundle qui a fourni cette instance de générateur.
35 void writeArrayFieldStart(String fieldName)- Méthode pratique pour afficher une entrée de champ ("membre") (qui contiendra une valeur de tableau JSON) et le marqueur START_ARRAY.
36 abstract void writeBinary(Base64Variant b64variant, byte[] data, int offset, int len)- Méthode qui affichera un morceau donné de données binaires encodées en base64, sous la forme d'une valeur String complète (entourée de guillemets doubles).
37 abstract int writeBinary(Base64Variant b64variant, InputStream data, int dataLength) - Méthode similaire à writeBinary (Base64Variant, byte [], int, int), mais où l'entrée est fournie via un flux, permettant des écritures incrémentielles sans conserver toute l'entrée en mémoire.
38 void writeBinary(byte[] data)- Similaire à writeBinary (Base64Variant, byte [], int, int), mais suppose par défaut d'utiliser la variante Base64 par défaut de Jackson (qui est Base64Variants.MIME_NO_LINEFEEDS).
39 void writeBinary(byte[] data, int offset, int len) - Similaire à writeBinary (Base64Variant, byte [], int, int), mais utilise par défaut la variante Base64 par défaut de Jackson (qui est Base64Variants.MIME_NO_LINEFEEDS).
40 int writeBinary(InputStream data, int dataLength) - Similaire à writeBinary (Base64Variant, InputStream, int), mais suppose l'utilisation par défaut de la variante Base64 par défaut de Jackson (qui est Base64Variants.MIME_NO_LINEFEEDS).
41 void writeBinaryField(String fieldName, byte[] data) - Méthode pratique pour la sortie d'une entrée de champ ("membre") qui contient des données spécifiées sous forme codée en base64.
42 abstract void writeBoolean(boolean state) - Méthode de sortie de la valeur booléenne Json littérale (une des chaînes 'true' et 'false').
43 void writeBooleanField(String fieldName, boolean value) - Méthode pratique pour sortir une entrée de champ ("membre") qui a une valeur booléenne.
44 abstract void writeEndArray() - Méthode d'écriture du marqueur de fermeture d'une valeur de tableau JSON (caractère ']'; plus possible décoration d'espaces blancs si l'impression jolie est activée).
45 abstract void writeEndObject() - Méthode d'écriture du marqueur de fermeture d'une valeur d'objet JSON (caractère '}'; plus possible décoration d'espace blanc si l'impression jolie est activée).
46 abstract void writeFieldName(SerializableString name) - Méthode similaire à writeFieldName (String), la principale différence étant qu'elle peut fonctionner mieux car certains traitements (tels que la citation de certains caractères ou l'encodage en encodage externe si pris en charge par le générateur) peuvent être effectués une seule fois et réutilisés pour des appels ultérieurs
47 abstract void writeFieldName(String name) - Méthode d'écriture d'un nom de champ (chaîne JSON entourée de guillemets doubles: syntaxiquement identique à une valeur chaîne JSON), éventuellement décorée d'un espace blanc si la jolie impression est activée.
48 abstract void writeNull() - Méthode de sortie de la valeur NULL Json littérale.
49 void writeNullField(String fieldName) - Méthode pratique pour générer une entrée de champ ("membre") qui a une valeur littérale JSON null.
50 abstract void writeNumber(BigDecimal dec) - La méthode de sortie indique la valeur numérique Json.
51 abstract void writeNumber(BigInteger v) - Méthode de sortie de la valeur donnée sous forme de nombre Json.
52 abstract void writeNumber(double d) - La méthode de sortie indique la valeur numérique Json.
53 abstract void writeNumber(float f) - La méthode de sortie indique la valeur numérique Json.
54 abstract void writeNumber(int v) - Méthode de sortie de la valeur donnée sous forme de nombre Json.
55 abstract void writeNumber(long v) - Méthode de sortie de la valeur donnée sous forme de nombre Json.
56 void writeNumber(short v) - Méthode de sortie de la valeur donnée sous forme de nombre Json.
57 abstract void writeNumber(String encodedValue) - Méthode d'écriture qui peut être utilisée pour les types numériques personnalisés qui ne peuvent pas être (facilement?) Convertis en types de nombres Java "standard".
58 void writeNumberField(String fieldName, BigDecimal value) - Méthode pratique pour la sortie d'une entrée de champ ("membre") qui a la valeur numérique spécifiée.
59 void writeNumberField(String fieldName, double value) - Méthode pratique pour la sortie d'une entrée de champ ("membre") qui a la valeur numérique spécifiée.
60 void writeNumberField(String fieldName, float value) - Méthode pratique pour la sortie d'une entrée de champ ("membre") qui a la valeur numérique spécifiée.
61 void writeNumberField(String fieldName, int value) - Méthode pratique pour la sortie d'une entrée de champ ("membre") qui a la valeur numérique spécifiée.
62 void writeNumberField(String fieldName, long value) - Méthode pratique pour la sortie d'une entrée de champ ("membre") qui a la valeur numérique spécifiée.
63 abstract void writeObject(Object pojo) - Méthode d'écriture d'un objet Java donné (POJO) comme Json.
64 void writeObjectField(String fieldName, Object pojo) - Méthode pratique pour sortir une entrée de champ ("membre") qui a le contenu d'un objet Java spécifique comme valeur.
65 void writeObjectFieldStart(String fieldName) - Méthode pratique pour afficher une entrée de champ ("membre") (qui contiendra une valeur d'objet JSON) et le marqueur START_OBJECT.
66 void writeObjectId(Object id) - Méthode qui peut être appelée pour afficher ce que l'on appelle l'ID d'objet natif.
67 void writeObjectRef(Object id) - Méthode qui peut être appelée pour générer des références aux identifiants d'objets natifs.
68 void writeOmittedField(String fieldName) Method called to indicate that a property in this position was skipped.
69 abstract void writeRaw(char c) - Méthode qui forcera le générateur à copier le texte d'entrée textuellement sans aucune modification (y compris qu'aucun échappement n'est effectué et qu'aucun séparateur n'est ajouté même si le contexte [tableau, objet] l'exigerait autrement).
70 abstract void writeRaw(char[] text, int offset, int len) - Méthode qui forcera le générateur à copier le texte d'entrée textuellement sans aucune modification (y compris qu'aucun échappement n'est effectué et qu'aucun séparateur n'est ajouté même si le contexte [tableau, objet] l'exigerait autrement).
71 void writeRaw(SerializableString raw) - Méthode qui forcera le générateur à copier le texte d'entrée textuellement sans aucune modification (y compris qu'aucun échappement n'est effectué et qu'aucun séparateur n'est ajouté même si le contexte [tableau, objet] l'exigerait autrement).
72 abstract void writeRaw(String text) - Méthode qui forcera le générateur à copier le texte d'entrée textuellement sans aucune modification (y compris qu'aucun échappement n'est effectué et qu'aucun séparateur n'est ajouté même si le contexte [tableau, objet] l'exigerait autrement).
73 abstract void writeRaw(String text, int offset, int len) - Méthode qui forcera le générateur à copier le texte d'entrée textuellement sans aucune modification (y compris qu'aucun échappement n'est effectué et qu'aucun séparateur n'est ajouté même si le contexte [tableau, objet] l'exigerait autrement).
74 abstract void writeRawUTF8String(byte[] text, int offset, int length) - Méthode similaire à writeString (String) mais qui prend comme entrée une String encodée en UTF-8 qui doit être sortie telle quelle, sans échappement supplémentaire (dont le type dépend du format des données; barres obliques inverses pour JSON).
75 abstract void writeRawValue(char[] text, int offset, int len)
76 abstract void writeRawValue(String text)- Méthode qui forcera le générateur à copier le texte d'entrée textuellement sans aucune modification, mais en supposant qu'il doit constituer une seule valeur JSON légale (nombre, chaîne, booléen, nul, tableau ou liste).
77 abstract void writeRawValue(String text, int offset, int len)
78 abstract void writeStartArray()- Méthode d'écriture du marqueur de départ d'une valeur JSON Array (caractère '['; plus possible décoration d'espace blanc si la jolie impression est activée).
79 abstract void writeStartObject() - Méthode d'écriture du marqueur de départ d'une valeur d'objet JSON (caractère '{'; plus possible décoration d'espace blanc si l'impression jolie est activée).
80 abstract void writeString(char[] text, int offset, int len) - Méthode de sortie d'une valeur String.
81 abstract void writeString(SerializableString text) - Method similar to writeString(String), but that takes SerializableString which can make this potentially more efficient to call as generator may be able to reuse quoted and/or encoded representation.
82 abstract void writeString(String text) - Method for outputting a String value.
83 void writeStringField(String fieldName, String value) - Convenience method for outputting a field entry ("member") that has a String value.
84 abstract void writeTree(TreeNode rootNode) - Method for writing given JSON tree (expressed as a tree where given JsonNode is the root) using this generator.
85 void writeTypeId(Object id) - Method that can be called to output so-called native Type Id.
86 abstract void writeUTF8String(byte[] text, int offset, int length) - Method similar to writeString(String) but that takes as its input a UTF-8 encoded String which has not been escaped using whatever escaping scheme data format requires (for JSON that is backslash-escaping for control characters and double-quotes; for other formats something else).

Methods inherited

This class inherits methods from the following classes:

  • java.lang.Object

JsonParser Class

Introduction

JsonParser is the base class to define public API for reading Json content. Instances are created using factory methods of a JsonFactory instance.

Class declaration

Following is the declaration for com.fasterxml.jackson.core.JsonParser class:

public abstract class JsonParser
   extends Object
      implements Closeable, Versioned

Nested Classes

S.N. Class & Description
1 static class JsonParser.Feature
Enumeration that defines all togglable features for parsers.
2 static class JsonParser.NumberType
Enumeration of possible "native" (optimal) types that can be used for numbers.

Fields

  • protected int _features - Bit flag composed of bits that indicate which JsonParser.Features are enabled.

Constructors

S.N. Constructor & Description
1 protected JsonParser()
Default constructor
2 protected JsonParser(int features)

Class Methods

S.N. Method & Description
1 protected JsonParseException _constructError(String msg) - Helper method for constructing JsonParseExceptions based on current state of the parser.
2 protected void _reportUnsupportedOperation() - Helper method to call for operations that are not supported by parser implementation.
3 boolean canReadObjectId() - Introspection method that may be called to see if the underlying data format supports some kind of Object Ids natively (many do not; for example, JSON doesn't).
4 boolean canReadTypeId() - Introspection method that may be called to see if the underlying data format supports some kind of Type Ids natively (many do not; for example, JSON doesn't).
5 boolean canUseSchema(FormatSchema schema) - Method that can be used to verify that given schema can be used with this parser (using setSchema(com.fasterxml.jackson.core.FormatSchema)).
6 abstract void clearCurrentToken() - Method called to "consume" the current token by effectively removing it so that hasCurrentToken() returns false, and getCurrentToken() null).
7 abstract void close() - Closes the parser so that no further iteration or data access can be made; will also close the underlying input source if parser either owns the input source, or feature JsonParser.Feature.AUTO_CLOSE_SOURCE is enabled.
8 JsonParser configure(JsonParser.Feature f, boolean state) - Method for enabling or disabling specified feature (check JsonParser.Feature for list of features)
9 JsonParser disable(JsonParser.Feature f) - Method for disabling specified feature (check JsonParser.Feature for list of features)
10 JsonParser enable(JsonParser.Feature f) - Method for enabling specified parser feature (check JsonParser.Feature for list of features)
11 abstract BigInteger getBigIntegerValue() - Numeric accessor that can be called when the current token is of type JsonToken.VALUE_NUMBER_INT and it can not be used as a Java long primitive type due to its magnitude.
12 byte[] getBinaryValue() - Convenience alternative to getBinaryValue(Base64Variant) that defaults to using Base64Variants.getDefaultVariant() as the default encoding.
13 abstract byte[] getBinaryValue(Base64Variant b64variant) - Method that can be used to read (and consume -- results may not be accessible using other methods after the call) base64-encoded binary data included in the current textual JSON value.
14 boolean getBooleanValue() - Convenience accessor that can be called when the current token is JsonToken.VALUE_TRUE or JsonToken.VALUE_FALSE.
15 byte getByteValue() - Numeric accessor that can be called when the current token is of type JsonToken.VALUE_NUMBER_INT and it can be expressed as a value of Java byte primitive type.
16 abstract ObjectCodec getCodec() - Accessor for ObjectCodec associated with this parser, if any.
17 abstract JsonLocation getCurrentLocation() - Method that returns location of the last processed character; usually for error reporting purposes.
18 abstract String getCurrentName() - Method that can be called to get the name associated with the current token: for JsonToken.FIELD_NAMEs it will be the same as what getText() returns; for field values it will be preceding field name; and for others (array values, root-level values) null.
19 abstract JsonToken getCurrentToken() - Accessor to find which token parser currently points to, if any; null will be returned if none.
20 abstract int getCurrentTokenId() - Method similar to getCurrentToken() but that returns an int instead of JsonToken (enum value).
21 abstract BigDecimal getDecimalValue() - Numeric accessor that can be called when the current token is of type JsonToken.VALUE_NUMBER_FLOAT or JsonToken.VALUE_NUMBER_INT.
22 abstract double getDoubleValue() - Numeric accessor that can be called when the current token is of type JsonToken.VALUE_NUMBER_FLOAT and it can be expressed as a Java double primitive type.
23 abstract Object getEmbeddedObject() - Accessor that can be called if (and only if) the current token is JsonToken.VALUE_EMBEDDED_OBJECT.
24 int getFeatureMask() - Bulk access method for getting state of all standard JsonParser.Features.
25 abstract float getFloatValue() - Numeric accessor that can be called when the current token is of type JsonToken.VALUE_NUMBER_FLOAT and it can be expressed as a Java float primitive type.
26 Object getInputSource() - Method that can be used to get access to object that is used to access input being parsed; this is usually either InputStream or Reader, depending on what parser was constructed with.
27 abstract int getIntValue() - Numeric accessor that can be called when the current token is of type JsonToken.VALUE_NUMBER_INT and it can be expressed as a value of Java int primitive type.
28 abstract JsonToken getLastClearedToken() - Method that can be called to get the last token that was cleared using clearCurrentToken().
29 abstract long getLongValue() - Numeric accessor that can be called when the current token is of type JsonToken.VALUE_NUMBER_INT and it can be expressed as a Java long primitive type.
30 abstract JsonParser.NumberType getNumberType() - If current token is of type JsonToken.VALUE_NUMBER_INT or JsonToken.VALUE_NUMBER_FLOAT, returns one of JsonParser.NumberType constants; otherwise returns null.
31 abstract Number getNumberValue() - Generic number value accessor method that will work for all kinds of numeric values.
32 Object getObjectId() - Method that can be called to check whether current token (one that was just read) has an associated Object id, and if so, return it.
33 abstract JsonStreamContext getParsingContext() - Method that can be used to access current parsing context reader is in.
34 FormatSchema getSchema() - Method for accessing Schema that this parser uses, if any.
35 short getShortValue() - Numeric accessor that can be called when the current token is of type JsonToken.VALUE_NUMBER_INT and it can be expressed as a value of Java short primitive type.
36 abstract String getText() - Method for accessing textual representation of the current token; if no current token (before first call to nextToken(), or after encountering end-of-input), returns null.
37 abstract char[] getTextCharacters() - Method similar to getText(), but that will return underlying (unmodifiable) character array that contains textual value, instead of constructing a String object to contain this information.
38 abstract int getTextLength() - Accessor used with getTextCharacters(), to know length of String stored in returned buffer.
39 abstract int getTextOffset() - Accessor used with getTextCharacters(), to know offset of the first text content character within buffer.
40 abstract JsonLocation getTokenLocation() - Method that return the starting location of the current token; that is, position of the first character from input that starts the current token.
41 Object getTypeId() - Method that can be called to check whether current token (one that was just read) has an associated type id, and if so, return it.
42 boolean getValueAsBoolean() - Method that will try to convert value of current token to a boolean.
43 boolean getValueAsBoolean(boolean defaultValue) - Method that will try to convert value of current token to a boolean.
44 double getValueAsDouble() - Method that will try to convert value of current token to a Java double.
45 double getValueAsDouble(double defaultValue) - Method that will try to convert value of current token to a Java double.
46 int getValueAsInt() - Method that will try to convert value of current token to a int.
47 int getValueAsInt(int defaultValue) - Method that will try to convert value of current token to a int.
48 long getValueAsLong() - Method that will try to convert value of current token to a long.
49 long getValueAsLong(long defaultValue) - Method that will try to convert value of current token to a long.
50 String getValueAsString() - Method that will try to convert value of current token to a String.
51 abstract String getValueAsString(String defaultValue) - Method that will try to convert value of current token to a String.
52 abstract boolean hasCurrentToken() - Method for checking whether parser currently points to a token (and data for that token is available).
53 abstract boolean hasTextCharacters() - Method that can be used to determine whether calling of getTextCharacters() would be the most efficient way to access textual content for the event parser currently points to.
54 abstract boolean isClosed() - Method that can be called to determine whether this parser is closed or not.
55 boolean isEnabled(JsonParser.Feature f) - Method for checking whether specified JsonParser.Feature is enabled.
56 boolean isExpectedStartArrayToken() - Specialized accessor that can be used to verify that the current token indicates start array (usually meaning that current token is JsonToken.START_ARRAY) when start array is expected.
57 Boolean nextBooleanValue() - Method that fetches next token (as if calling nextToken()) and if it is JsonToken.VALUE_TRUE or JsonToken.VALUE_FALSE returns matching Boolean value; otherwise return null.
58 boolean nextFieldName(SerializableString str) - Method that fetches next token (as if calling nextToken()) and verifies whether it is JsonToken.FIELD_NAME with specified name and returns result of that comparison.
59 int nextIntValue(int defaultValue) - Method that fetches next token (as if calling nextToken()) and if it is JsonToken.VALUE_NUMBER_INT returns 32-bit int value; otherwise returns specified default value It is functionally equivalent to:
60 long nextLongValue(long defaultValue) - Method that fetches next token (as if calling nextToken()) and if it is JsonToken.VALUE_NUMBER_INT returns 64-bit long value; otherwise returns specified default value It is functionally equivalent to:
61 String nextTextValue() - Method that fetches next token (as if calling nextToken()) and if it is JsonToken.VALUE_STRING returns contained String value; otherwise returns null.
62 abstract JsonToken nextToken() - Main iteration method, which will advance stream enough to determine type of the next token, if any.
63 abstract JsonToken nextValue() - Iteration method that will advance stream enough to determine type of the next token that is a value type (including JSON Array and Object start/end markers).
64 abstract void overrideCurrentName(String name) - Method that can be used to change what is considered to be the current (field) name.
65 int readBinaryValue(Base64Variant b64variant, OutputStream out) - Similar to readBinaryValue(OutputStream) but allows explicitly specifying base64 variant to use.
66 int readBinaryValue(OutputStream out) - Method that can be used as an alternative to getBigIntegerValue(), especially when value can be large.
67 <T> T readValueAs(Class<T> valueType) - Method to deserialize JSON content into a non-container type (it can be an array type, however): typically a bean, array or a wrapper type (like Boolean).
68 <T> T readValueAs(TypeReference<?> valueTypeRef)- Method to deserialize JSON content into a Java type, reference to which is passed as argument.
69 <T extends TreeNode> T readValueAsTree() - Method to deserialize JSON content into equivalent "tree model", represented by root TreeNode of resulting model.
70 <T> Iterator<T> readValuesAs(Class<T> valueType) - Method for reading sequence of Objects from parser stream, all with same specified value type.
71 <T> Iterator<T> readValuesAs(TypeReference<?> valueTypeRef)- Method for reading sequence of Objects from parser stream, all with same specified value type.
72 int releaseBuffered(OutputStream out) - Method that can be called to push back any content that has been read but not consumed by the parser.
73 int releaseBuffered(Writer w) - Method that can be called to push back any content that has been read but not consumed by the parser.
74 boolean requiresCustomCodec() - Method that can be called to determine if a custom ObjectCodec is needed for binding data parsed using JsonParser constructed by this factory (which typically also implies the same for serialization with JsonGenerator).
75 abstract void setCodec(ObjectCodec c) - Setter that allows defining ObjectCodec associated with this parser, if any.
76 JsonParser setFeatureMask(int mask) - Bulk set method for (re)settting states of all standard JsonParser.Features
77 void setSchema(FormatSchema schema) - Method to call to make this parser use specified schema.
78 abstract JsonParser skipChildren() - Method that will skip all child tokens of an array or object token that the parser currently points to, iff stream points to JsonToken.START_OBJECT or JsonToken.START_ARRAY.
79 abstract Version version() - Accessor for getting version of the core package, given a parser instance.

Methods inherited

This class inherits methods from the following classes:

  • java.lang.Object