Interface JsonParser

  • All Superinterfaces:
    java.lang.AutoCloseable, java.io.Closeable

    public interface JsonParser
    extends java.io.Closeable
    Provides forward, read-only access to JSON data in a streaming way. This is the most efficient way for reading JSON data.

    This is a near-exact copy of the same-titled Java EE 8 Class: javax.json.stream.JsonParser
    Commenting has been slightly modified to accompany HiLited Code Examples.
    Java Source Code remains identical to the Sun-Oracle & 'GlassFish' Released Distributions.

    Read included License: HERE, and the CDDL+GPL-1.1
    All javax.json.stream.* Code Obtained From: GitHub JavaEE jsonp  Public Archive.


    This is the only way to parse and process JSON data that are too big to be loaded in memory.

    The class Json contains methods to create parsers from input sources (InputStream and Reader).

    The following example demonstrates how to create a parser from a string that contains an empty JSON array:

     JsonParser parser = Json.createParser(new StringReader("[]"));
    


    The class JsonParserFactory also contains methods to create JsonParser instances. JsonParserFactory is preferred when creating multiple parser instances. A sample usage is shown in the following example:

     JsonParserFactory    factory = Json.createParserFactory();
     JsonParser           parser1 = factory.createParser(...);
     JsonParser           parser2 = factory.createParser(...);
    


    JsonParser parses JSON using the pull parsing programming model. In this model the client code controls the thread and calls the method next() to advance the parser to the next state after processing each element. The parser can generate the following events: START_OBJECT, END_OBJECT, START_ARRAY, END_ARRAY, KEY_NAME, VALUE_STRING, VALUE_NUMBER, VALUE_TRUE, VALUE_FALSE, and VALUE_NULL.

    For example, for an empty JSON object ({ }), the parser generates the event START_OBJECT with the first call to the method next() and the event END_OBJECT with the second call to the method next(). The following code demonstrates how to access these events:

     Event event = parser.next(); // START_OBJECT
     event = parser.next();       // END_OBJECT
    


    For example, for the following JSON:

    Java Script Object Notation (JSON):
     {
       "firstName": "John", "lastName": "Smith", "age": 25,
       "phoneNumber": [
           { "type": "home", "number": "212 555-1234" },
           { "type": "fax", "number": "646 555-4567" }
        ]
     }
    

    Calls to the method next() result in parse events at the specified locations below (marked in bold):

    {<B>START_OBJECT</B> "firstName"<B>KEY_NAME</B>: "John"<B>VALUE_STRING</B>, "lastName"<B>KEY_NAME</B>: "Smith"<B>VALUE_STRING</B>, "age"<B>KEY_NAME</B>: 25<B>VALUE_NUMBER</B>, "phoneNumber"<B>KEY_NAME</B> : [<B>START_ARRAY</B> {<B>START_OBJECT</B> "type"<B>KEY_NAME</B>: "home"<B>VALUE_STRING</B>, "number"<B>KEY_NAME</B>: "212 555-1234"<B>VALUE_STRING</B> }<B>END_OBJECT</B>, {<B>START_OBJECT</B> "type"<B>KEY_NAME</B>: "fax"<B>VALUE_STRING</B>, "number"<B>KEY_NAME</B>: "646 555-4567"<B>VALUE_STRING</B> }<B>END_OBJECT</B> ]<B>END_ARRAY</B> }<B>END_OBJECT</B>

    The methods next() and hasNext() enable iteration over parser events to process JSON data. JsonParser provides get methods to obtain the value at the current state of the parser. For example, the following code shows how to obtain the value "John" from the JSON above:

    Example:
     Event event = parser.next(); // START_OBJECT
     event = parser.next();       // KEY_NAME
     event = parser.next();       // VALUE_STRING
     parser.getString();          // "John"
    

    Starting in version 1.1, it is possible to build a partial JSON object model from the stream, at the current parser position. The methods getArray() and getObject() can be used to read in a JsonArray or JsonObject. For example, the following code shows how to obtain the phoneNumber in a JsonArray, from the JSON above:

    Example:
     while (parser.hasNext())
     {
          Event event = parser.next();
     
          if (event == JsonParser.Event.KEY_NAME)
          {
             String key = getString();
             event = parser.next();
    
             if (key.equals("phoneNumber")
                 JsonArray phones = parser.getArray();
          }
     }
    

    The methods getArrayStream() and getObjectStream() can be used to get a stream of the elements of a JsonArray or JsonObject. For example, the following code shows another way to obtain John's phoneNumber in a JsonArray :

    Example:
     Event event = parser.next(); // START_OBJECT
     
     JsonArray phones = (JsonArray) parser
          .getObjectStream()
          .filter(e->e.getKey().equals("phoneNumber"))
          .map(e->e.getValue())
          .findFirst()
          .get();
    

    The methods skipArray() and skipObject() can be used to skip tokens and position the parser to END_ARRAY or END_OBJECT.

    JsonParser can be used to parse sequence of JSON values that are not enclosed in a JSON array, e.g. { } { }. The following code demonstrates how to parse such sequence.

    Example:
     JsonParser parser = Json.createParser(...);
     
     while (parser.hasNext)
     {
         parser.next(); // advance parser state
         JsonValue value = parser.getValue();
     }
    
    See Also:
    Json, JsonParserFactory


    • Nested Class Summary

      Nested Classes 
      Modifier and Type Interface Description
      static class  JsonParser.Event
      An event from JsonParser.
    • Method Summary

      All Methods Instance Methods Abstract Methods Default Methods 
      Modifier and Type Method Description
      void close()
      Closes this parser and frees any resources associated with the parser.
      default JsonArray getArray()
      Returns a JsonArray and advance the parser to the the corresponding END_ARRAY.
      default Stream<JsonValue> getArrayStream()
      Returns a stream of the JsonArray elements.
      BigDecimal getBigDecimal()
      Returns a JSON number as a BigDecimal.
      int getInt()
      Returns a JSON number as an integer.
      JsonLocation getLocation()
      Return the location that corresponds to the parser's current state in the JSON input source.
      long getLong()
      Returns a JSON number as a long.
      default JsonObject getObject()
      Returns a JsonObject and advances the parser to the corresponding END_OBJECT.
      default Stream<Map.Entry<String,
           ​JsonValue>>
      getObjectStream()
      Returns a stream of the JsonObject's name/value pairs.
      String getString()
      Returns a String for the name in a name/value pair, for a string value or a number value.
      default JsonValue getValue()
      Returns a JsonValue at the current parser position.
      default Stream<JsonValue> getValueStream()
      Returns a stream of JsonValue from a sequence of JSON values.
      boolean hasNext()
      Returns true if there are more parsing states.
      boolean isIntegralNumber()
      Returns true if the JSON number at the current parser state is a integral number.
      JsonParser.Event next()
      Returns the event for the next parsing state.
      default void skipArray()
      Advance the parser to END_ARRAY.
      default void skipObject()
      Advance the parser to END_OBJECT.
    • Method Detail

      • hasNext

        🡇     🗕  🗗  🗖
        boolean hasNext()
        Returns true if there are more parsing states. This method returns false if the parser reaches the end of the JSON text.
        Returns:
        true if there are more parsing states.
        Throws:
        JsonException - if an i/o error occurs (IOException would be cause of JsonException)
        JsonParsingException - if the parser encounters invalid JSON when advancing to next state.
      • next

        🡅  🡇     🗕  🗗  🗖
        JsonParser.Event next()
        Returns the event for the next parsing state.
        Returns:
        the event for the next parsing state
        Throws:
        JsonException - if an i/o error occurs (IOException would be cause of JsonException)
        JsonParsingException - if the parser encounters invalid JSON when advancing to next state.
        java.util.NoSuchElementException - if there are no more parsing states.
      • isIntegralNumber

        🡅  🡇     🗕  🗗  🗖
        boolean isIntegralNumber()
        Returns true if the JSON number at the current parser state is a integral number. A BigDecimal may be used to store the value internally and this method semantics are defined using its scale(). If the scale is zero, then it is considered integral type. This integral type information can be used to invoke an appropriate accessor method to obtain a numeric value as in the following example:
         
         JsonParser parser = ...
         
         if (parser.isIntegralNumber())
             parser.getInt();     // or other methods to get integral value
         else
             parser.getBigDecimal();
        
         
         
        Returns:
        true if this number is a integral number, otherwise false
        Throws:
        java.lang.IllegalStateException - when the parser state is not VALUE_NUMBER
      • getInt

        🡅  🡇     🗕  🗗  🗖
        int getInt()
        Returns a JSON number as an integer. The returned value is equal to new BigDecimal(getString()).intValue(). Note that this conversion can lose information about the overall magnitude and precision of the number value as well as return a result with the opposite sign. This method should only be called when the parser state is JsonParser.Event.VALUE_NUMBER.
        Returns:
        an integer for a JSON number
        Throws:
        java.lang.IllegalStateException - when the parser state is not VALUE_NUMBER
        See Also:
        BigDecimal.intValue()
      • getLong

        🡅  🡇     🗕  🗗  🗖
        long getLong()
        Returns a JSON number as a long. The returned value is equal to new BigDecimal(getString()).longValue(). Note that this conversion can lose information about the overall magnitude and precision of the number value as well as return a result with the opposite sign. This method is only called when the parser state is JsonParser.Event.VALUE_NUMBER.
        Returns:
        a long for a JSON number
        Throws:
        java.lang.IllegalStateException - when the parser state is not VALUE_NUMBER
        See Also:
        BigDecimal.longValue()
      • getBigDecimal

        🡅  🡇     🗕  🗗  🗖
        java.math.BigDecimal getBigDecimal()
        Returns a JSON number as a BigDecimal. The BigDecimal is created using new BigDecimal(getString()). This method should only called when the parser state is JsonParser.Event.VALUE_NUMBER.
        Returns:
        a BigDecimal for a JSON number
        Throws:
        java.lang.IllegalStateException - when the parser state is not VALUE_NUMBER
      • getLocation

        🡅  🡇     🗕  🗗  🗖
        JsonLocation getLocation()
        Return the location that corresponds to the parser's current state in the JSON input source. The location information is only valid in the current parser state (or until the parser is advanced to a next state).
        Returns:
        a non-null location corresponding to the current parser state in JSON input source
      • getObject

        🡅  🡇     🗕  🗗  🗖
        default JsonObject getObject()
        Returns a JsonObject and advances the parser to the corresponding END_OBJECT.
        Returns:
        the JsonObject at the current parser position
        Throws:
        java.lang.IllegalStateException - when the parser state is not START_OBJECT
        Since:
        1.1
        Code:
        Exact Method Body:
         throw new UnsupportedOperationException();
        
      • getValue

        🡅  🡇     🗕  🗗  🗖
        default JsonValue getValue()
        Returns a JsonValue at the current parser position. If the parser state is START_ARRAY, the behavior is the same as getArray(). If the parser state is START_OBJECT, the behavior is the same as getObject(). For all other cases, if applicable, the JSON value is read and returned.
        Returns:
        the JsonValue at the current parser position.
        Throws:
        java.lang.IllegalStateException - when the parser state is END_OBJECT or END_ARRAY
        Since:
        1.1
        Code:
        Exact Method Body:
         throw new UnsupportedOperationException();
        
      • getArray

        🡅  🡇     🗕  🗗  🗖
        default JsonArray getArray()
        Returns a JsonArray and advance the parser to the the corresponding END_ARRAY.
        Returns:
        the JsonArray at the current parser position
        Throws:
        java.lang.IllegalStateException - when the parser state is not START_ARRAY
        Since:
        1.1
        Code:
        Exact Method Body:
         throw new UnsupportedOperationException();
        
      • getArrayStream

        🡅  🡇     🗕  🗗  🗖
        default java.util.stream.Stream<JsonValuegetArrayStream()
        Returns a stream of the JsonArray elements. The parser state must be START_ARRAY. The elements are read lazily, on an as-needed basis, as required by the stream operations. If the stream operations do not consume all of the array elements, skipArray() can be used to skip the unprocessed array elements.
        Returns:
        a stream of elements of the JsonArray
        Throws:
        java.lang.IllegalStateException - when the parser state is not START_ARRAY
        Since:
        1.1
        Code:
        Exact Method Body:
         throw new UnsupportedOperationException();
        
      • getObjectStream

        🡅  🡇     🗕  🗗  🗖
        default java.util.stream.Stream<java.util.Map.Entry<java.lang.String,​JsonValue>> getObjectStream
                    ()
        
        Returns a stream of the JsonObject's name/value pairs. The parser state must be START_OBJECT. The name/value pairs are read lazily, on an as-needed basis, as required by the stream operations. If the stream operations do not consume all of the object's name/value pairs, skipObject() can be used to skip the unprocessed elements.
        Returns:
        a stream of name/value pairs of the JsonObject
        Throws:
        java.lang.IllegalStateException - when the parser state is not START_OBJECT
        Since:
        1.1
        Code:
        Exact Method Body:
         throw new UnsupportedOperationException();
        
      • getValueStream

        🡅  🡇     🗕  🗗  🗖
        default java.util.stream.Stream<JsonValuegetValueStream()
        Returns a stream of JsonValue from a sequence of JSON values. The values are read lazily, on an as-needed basis, as needed by the stream operations.
        Returns:
        a Stream of JsonValue
        Throws:
        java.lang.IllegalStateException - if the parser is in an array or object.
        Since:
        1.1
        Code:
        Exact Method Body:
         throw new UnsupportedOperationException();
        
      • skipArray

        🡅  🡇     🗕  🗗  🗖
        default void skipArray()
        Advance the parser to END_ARRAY. If the parser is in array context, i.e. it has previously encountered a START_ARRAY without encountering the corresponding END_ARRAY, the parser is advanced to the corresponding END_ARRAY. If the parser is not in any array context, nothing happens.
        Since:
        1.1
        Code:
        Exact Method Body:
         throw new UnsupportedOperationException();
        
      • skipObject

        🡅  🡇     🗕  🗗  🗖
        default void skipObject()
        Advance the parser to END_OBJECT. If the parser is in object context, i.e. it has previously encountered a START_OBJECT without encountering the corresponding END_OBJECT, the parser is advanced to the corresponding END_OBJECT. If the parser is not in any object context, nothing happens.
        Since:
        1.1
        Code:
        Exact Method Body:
         throw new UnsupportedOperationException();
        
      • close

        🡅     🗕  🗗  🗖
        void close()
        Closes this parser and frees any resources associated with the parser. This method closes the underlying input source.
        Specified by:
        close in interface java.lang.AutoCloseable
        Specified by:
        close in interface java.io.Closeable
        Throws:
        JsonException - if an i/o error occurs (IOException would be cause of JsonException)