public abstract class JsonNode extends JsonSerializable.Base implements com.fasterxml.jackson.core.TreeNode, Iterable<JsonNode>
As a general design rule, most accessors ("getters") are included
in this base class, to allow for traversing structure without
type casts. Most mutators, however, need to be accessed through
specific sub-classes (such as ObjectNode
and ArrayNode
).
This seems sensible because proper type
information is generally available when building or modifying
trees, but less often when reading a tree (newly built from
parsed JSON content).
Actual concrete sub-classes can be found from package
com.fasterxml.jackson.databind.node
.
Note that it is possible to "read" from nodes, using
method TreeNode.traverse(ObjectCodec)
, which will result in
a JsonParser
being constructed. This can be used for (relatively)
efficient conversations between different representations; and it is what
core databind uses for methods like ObjectMapper.treeToValue(TreeNode, Class)
and ObjectMapper.treeAsTokens(TreeNode)
Modifier and Type | Class and Description |
---|---|
static class |
JsonNode.OverwriteMode
Configuration setting used with
withObject(JsonPointer)
method overrides, to indicate which overwrites are acceptable if the
path pointer indicates has incompatible nodes (for example, instead
of Object node a Null node is encountered). |
JsonSerializable.Base
Modifier | Constructor and Description |
---|---|
protected |
JsonNode() |
Modifier and Type | Method and Description |
---|---|
protected abstract JsonNode |
_at(com.fasterxml.jackson.core.JsonPointer ptr)
Helper method used by other methods for traversing the next step
of given path expression, and returning matching value node if any:
if no match,
null is returned. |
protected <T> T |
_reportRequiredViolation(String msgTemplate,
Object... args)
Helper method that throws
IllegalArgumentException as a result of
violating "required-constraint" for this node (for required(java.lang.String) or related
methods). |
protected <T extends JsonNode> |
_this() |
boolean |
asBoolean()
Method that will try to convert value of this node to a Java boolean.
|
boolean |
asBoolean(boolean defaultValue)
Method that will try to convert value of this node to a Java boolean.
|
double |
asDouble()
Method that will try to convert value of this node to a Java double.
|
double |
asDouble(double defaultValue)
Method that will try to convert value of this node to a Java double.
|
int |
asInt()
Method that will try to convert value of this node to a Java int.
|
int |
asInt(int defaultValue)
Method that will try to convert value of this node to a Java int.
|
long |
asLong()
Method that will try to convert value of this node to a Java long.
|
long |
asLong(long defaultValue)
Method that will try to convert value of this node to a Java long.
|
abstract String |
asText()
Method that will return a valid String representation of
the container value, if the node is a value node
(method
isValueNode() returns true),
otherwise empty String. |
String |
asText(String defaultValue)
Returns the text value of this node or the provided
defaultValue if this node
does not have a text value. |
JsonNode |
at(com.fasterxml.jackson.core.JsonPointer ptr)
Method for locating node specified by given JSON pointer instances.
|
JsonNode |
at(String jsonPtrExpr)
Convenience method that is functionally equivalent to:
|
BigInteger |
bigIntegerValue()
Returns integer value for this node (as
BigInteger ), if and only if
this node is numeric (isNumber() returns true). |
byte[] |
binaryValue()
Method to use for accessing binary content of binary nodes (nodes
for which
isBinary() returns true); or for Text Nodes
(ones for which textValue() returns non-null value),
to read decoded base64 data. |
boolean |
booleanValue()
Method to use for accessing JSON boolean values (value
literals 'true' and 'false').
|
boolean |
canConvertToExactIntegral()
Method that can be used to check whether contained value
is numeric (returns true for
isNumber() ) and
can be losslessly converted to integral number (specifically,
BigInteger but potentially others, see
canConvertToInt() and canConvertToInt() ). |
boolean |
canConvertToInt()
Method that can be used to check whether this node is a numeric
node (
isNumber() would return true) AND its value fits
within Java's 32-bit signed integer type, int . |
boolean |
canConvertToLong()
Method that can be used to check whether this node is a numeric
node (
isNumber() would return true) AND its value fits
within Java's 64-bit signed integer type, long . |
BigDecimal |
decimalValue()
Returns floating point value for this node (as
BigDecimal ), if and only if
this node is numeric (isNumber() returns true). |
abstract <T extends JsonNode> |
deepCopy()
Method that can be called to get a node that is guaranteed
not to allow changing of this node through mutators on
this node or any of its children.
|
double |
doubleValue()
Returns 64-bit floating point (double) value for this node, if and only if
this node is numeric (
isNumber() returns true). |
Iterator<JsonNode> |
elements()
Method for accessing all value nodes of this Node, iff
this node is a JSON Array or Object node.
|
boolean |
equals(Comparator<JsonNode> comparator,
JsonNode other)
Entry method for invoking customizable comparison, using passed-in
Comparator object. |
abstract boolean |
equals(Object o)
Equality for node objects is defined as full (deep) value
equality.
|
Iterator<String> |
fieldNames() |
Iterator<Map.Entry<String,JsonNode>> |
fields() |
abstract JsonNode |
findParent(String fieldName)
Method for finding a JSON Object that contains specified field,
within this node or its descendants.
|
List<JsonNode> |
findParents(String fieldName)
Method for finding a JSON Object that contains specified field,
within this node or its descendants.
|
abstract List<JsonNode> |
findParents(String fieldName,
List<JsonNode> foundSoFar) |
abstract JsonNode |
findPath(String fieldName)
Method similar to
findValue(java.lang.String) , but that will return a
"missing node" instead of null if no field is found. |
abstract JsonNode |
findValue(String fieldName)
Method for finding the first JSON Object field with specified name in this
node or its child nodes, and returning value it has.
|
List<JsonNode> |
findValues(String fieldName)
Method for finding JSON Object fields with specified name -- both immediate
child values and descendants -- and returning
found ones as a
List . |
abstract List<JsonNode> |
findValues(String fieldName,
List<JsonNode> foundSoFar) |
List<String> |
findValuesAsText(String fieldName)
Similar to
findValues(java.lang.String) , but will additionally convert
values into Strings, calling asText() . |
abstract List<String> |
findValuesAsText(String fieldName,
List<String> foundSoFar) |
float |
floatValue()
Returns 32-bit floating value for this node, if and only if
this node is numeric (
isNumber() returns true). |
abstract JsonNode |
get(int index)
Method for accessing value of the specified element of
an array node.
|
JsonNode |
get(String fieldName)
Method for accessing value of the specified field of
an object node.
|
abstract JsonNodeType |
getNodeType()
Return the type of this node
|
boolean |
has(int index)
Method that allows checking whether this node is JSON Array node
and contains a value for specified index
If this is the case
(including case of specified indexing having null as value), returns true;
otherwise returns false.
|
boolean |
has(String fieldName)
Method that allows checking whether this node is JSON Object node
and contains value for specified property.
|
boolean |
hasNonNull(int index)
Method that is similar to
has(int) , but that will
return false for explicitly added nulls. |
boolean |
hasNonNull(String fieldName)
Method that is similar to
has(String) , but that will
return false for explicitly added nulls. |
int |
intValue()
Returns integer value for this node, if and only if
this node is numeric (
isNumber() returns true). |
boolean |
isArray() |
boolean |
isBigDecimal() |
boolean |
isBigInteger() |
boolean |
isBinary()
Method that can be used to check if this node represents
binary data (Base64 encoded).
|
boolean |
isBoolean()
Method that can be used to check if this node was created from
JSON boolean value (literals "true" and "false").
|
boolean |
isContainerNode() |
boolean |
isDouble() |
boolean |
isEmpty()
Convenience method that is functionally same as:
|
boolean |
isFloat() |
boolean |
isFloatingPointNumber() |
boolean |
isInt()
Method that can be used to check whether contained value
is a number represented as Java
int . |
boolean |
isIntegralNumber() |
boolean |
isLong()
Method that can be used to check whether contained value
is a number represented as Java
long . |
boolean |
isMissingNode() |
boolean |
isNull()
Method that can be used to check if this node was created from
JSON literal null value.
|
boolean |
isNumber() |
boolean |
isObject() |
boolean |
isPojo()
Method that can be used to check if the node is a wrapper
for a POJO ("Plain Old Java Object" aka "bean".
|
boolean |
isShort()
Method that can be used to check whether contained value
is a number represented as Java
short . |
boolean |
isTextual()
Method that checks whether this node represents basic JSON String
value.
|
boolean |
isValueNode() |
Iterator<JsonNode> |
iterator()
Same as calling
elements() ; implemented so that
convenience "for-each" loop can be used for looping over elements
of JSON Array constructs. |
long |
longValue()
Returns 64-bit long value for this node, if and only if
this node is numeric (
isNumber() returns true). |
Number |
numberValue()
Returns numeric value for this node, if and only if
this node is numeric (
isNumber() returns true); otherwise
returns null |
abstract JsonNode |
path(int index)
This method is similar to
get(int) , except
that instead of returning null if no such element exists (due
to index being out of range, or this node not being an array),
a "missing node" (node that returns true for
isMissingNode() ) will be returned. |
abstract JsonNode |
path(String fieldName)
This method is similar to
get(String) , except
that instead of returning null if no such value exists (due
to this node not being an object, or object not having value
for the specified field),
a "missing node" (node that returns true for
isMissingNode() ) will be returned. |
Set<Map.Entry<String,JsonNode>> |
properties()
Accessor that will return properties of
ObjectNode
similar to how Map.entrySet() works;
for other node types will return empty Set . |
<T extends JsonNode> |
require()
Method that may be called to verify that
this node is NOT so-called
"missing node": that is, one for which isMissingNode() returns true . |
JsonNode |
required(int index)
Method is functionally equivalent to
path(index).required()
and can be used to check that this node is an ArrayNode (that is, represents
JSON Array value) and has value for specified index
(but note that value may be explicit JSON null value). |
JsonNode |
required(String propertyName)
Method is functionally equivalent to
path(fieldName).required()
and can be used to check that this node is an ObjectNode (that is, represents
JSON Object value) and has value for specified property with key fieldName
(but note that value may be explicit JSON null value). |
JsonNode |
requiredAt(com.fasterxml.jackson.core.JsonPointer path)
Method is functionally equivalent to
at(path).required()
and can be used to check that there is an actual value node at specified JsonPointer
starting from this node
(but note that value may be explicit JSON null value). |
JsonNode |
requiredAt(String pathExpr)
Method is functionally equivalent to
at(pathExpr).required()
and can be used to check that there is an actual value node at specified JsonPointer
starting from this node
(but note that value may be explicit JSON null value). |
<T extends JsonNode> |
requireNonNull()
Method that may be called to verify that
this node is neither so-called
"missing node" (that is, one for which isMissingNode() returns true )
nor "null node" (one for which isNull() returns true ). |
short |
shortValue()
Returns 16-bit short value for this node, if and only if
this node is numeric (
isNumber() returns true). |
int |
size() |
String |
textValue()
Method to use for accessing String values.
|
String |
toPrettyString()
Alternative to
toString() that will serialize this node using
Jackson default pretty-printer. |
abstract String |
toString()
Method that will produce (as of Jackson 2.10) valid JSON using
default settings of databind, as String.
|
<T extends JsonNode> |
with(String exprOrProperty)
Deprecated.
Since 2.14 use
withObject(String) instead |
ArrayNode |
withArray(com.fasterxml.jackson.core.JsonPointer ptr)
Same as
withArray(JsonPointer, OverwriteMode, boolean) but
with defaults of OvewriteMode#NULLS (overwrite mode)
and true for preferIndex . |
ArrayNode |
withArray(com.fasterxml.jackson.core.JsonPointer ptr,
JsonNode.OverwriteMode overwriteMode,
boolean preferIndex)
Method that can be called on Object or Array nodes, to access a Array-valued
node pointed to by given
JsonPointer , if such a node exists:
or if not, an attempt is made to create one and return it. |
<T extends JsonNode> |
withArray(String exprOrProperty)
Method that works in one of possible ways, depending on whether
exprOrProperty is a valid JsonPointer expression or
not (valid expression is either empty String "" or starts
with leading slash / character). |
ArrayNode |
withArray(String expr,
JsonNode.OverwriteMode overwriteMode,
boolean preferIndex)
Short-cut equivalent to:
|
ArrayNode |
withArrayProperty(String propName)
Method similar to
withArray(JsonPointer, OverwriteMode, boolean) -- basically
short-cut to: |
ObjectNode |
withObject(com.fasterxml.jackson.core.JsonPointer ptr)
Same as
withObject(JsonPointer, OverwriteMode, boolean) but
with defaults of OvewriteMode#NULLS (overwrite mode)
and true for preferIndex (that is, will try to
consider JsonPointer segments index if at all possible
and only secondarily as property name |
ObjectNode |
withObject(com.fasterxml.jackson.core.JsonPointer ptr,
JsonNode.OverwriteMode overwriteMode,
boolean preferIndex)
Method that can be called on Object or Array nodes, to access a Object-valued
node pointed to by given
JsonPointer , if such a node exists:
or if not, an attempt is made to create one and return it. |
ObjectNode |
withObject(String exprOrProperty)
Method that works in one of possible ways, depending on whether
exprOrProperty is a valid JsonPointer expression or
not (valid expression is either empty String "" or starts
with leading slash / character). |
ObjectNode |
withObject(String expr,
JsonNode.OverwriteMode overwriteMode,
boolean preferIndex)
Short-cut equivalent to:
|
ObjectNode |
withObjectProperty(String propName)
Method similar to
withObject(JsonPointer, OverwriteMode, boolean) -- basically
short-cut to: |
isEmpty
clone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
asToken, numberType, traverse, traverse
forEach, spliterator
serialize, serializeWithType
public abstract <T extends JsonNode> T deepCopy()
Note: return type is guaranteed to have same type as the node method is called on; which is why method is declared with local generic type.
public int size()
size
in interface com.fasterxml.jackson.core.TreeNode
public boolean isEmpty()
size() == 0for all node types.
public final boolean isValueNode()
isValueNode
in interface com.fasterxml.jackson.core.TreeNode
public final boolean isContainerNode()
isContainerNode
in interface com.fasterxml.jackson.core.TreeNode
public boolean isMissingNode()
isMissingNode
in interface com.fasterxml.jackson.core.TreeNode
public boolean isArray()
isArray
in interface com.fasterxml.jackson.core.TreeNode
public boolean isObject()
isObject
in interface com.fasterxml.jackson.core.TreeNode
public abstract JsonNode get(int index)
For array nodes, index specifies
exact location within array and allows for efficient iteration
over child elements (underlying storage is guaranteed to
be efficiently indexable, i.e. has random-access to elements).
If index is less than 0, or equal-or-greater than
node.size()
, null is returned; no exception is
thrown for any index.
NOTE: if the element value has been explicitly set as null
(which is different from removal!),
a NullNode
will be returned,
not null.
get
in interface com.fasterxml.jackson.core.TreeNode
public JsonNode get(String fieldName)
NOTE: if the property value has been explicitly set as null
(which is different from removal!),
a NullNode
will be returned,
not null.
get
in interface com.fasterxml.jackson.core.TreeNode
public abstract JsonNode path(String fieldName)
get(String)
, except
that instead of returning null if no such value exists (due
to this node not being an object, or object not having value
for the specified field),
a "missing node" (node that returns true for
isMissingNode()
) will be returned. This allows for
convenient and safe chained access via path calls.path
in interface com.fasterxml.jackson.core.TreeNode
public abstract JsonNode path(int index)
get(int)
, except
that instead of returning null if no such element exists (due
to index being out of range, or this node not being an array),
a "missing node" (node that returns true for
isMissingNode()
) will be returned. This allows for
convenient and safe chained access via path calls.path
in interface com.fasterxml.jackson.core.TreeNode
public Iterator<String> fieldNames()
fieldNames
in interface com.fasterxml.jackson.core.TreeNode
public final JsonNode at(com.fasterxml.jackson.core.JsonPointer ptr)
isMissingNode()
returns true.at
in interface com.fasterxml.jackson.core.TreeNode
isMissingNode()
returns true.public final JsonNode at(String jsonPtrExpr)
return at(JsonPointer.valueOf(jsonPointerExpression));
Note that if the same expression is used often, it is preferable to construct
JsonPointer
instance once and reuse it: this method will not perform
any caching of compiled expressions.
at
in interface com.fasterxml.jackson.core.TreeNode
jsonPtrExpr
- Expression to compile as a JsonPointer
instanceTreeNode.isMissingNode()
returns true.protected abstract JsonNode _at(com.fasterxml.jackson.core.JsonPointer ptr)
null
is returned.ptr
- Path expression to useJsonNode
for the first step of path or
null
if no match (including case that this node is not a container)public abstract JsonNodeType getNodeType()
JsonNodeType
enum valuepublic final boolean isPojo()
POJONode
.public final boolean isNumber()
public boolean isIntegralNumber()
public boolean isFloatingPointNumber()
public boolean isShort()
short
.
Note, however, that even if this method returns false, it
is possible that conversion would be possible from other numeric
types -- to check if this is possible, use
canConvertToInt()
instead.public boolean isInt()
int
.
Note, however, that even if this method returns false, it
is possible that conversion would be possible from other numeric
types -- to check if this is possible, use
canConvertToInt()
instead.public boolean isLong()
long
.
Note, however, that even if this method returns false, it
is possible that conversion would be possible from other numeric
types -- to check if this is possible, use
canConvertToLong()
instead.long
public boolean isFloat()
public boolean isDouble()
public boolean isBigDecimal()
public boolean isBigInteger()
public final boolean isTextual()
public final boolean isBoolean()
public final boolean isNull()
public final boolean isBinary()
isTextual()
will
return false if this method returns true.public boolean canConvertToInt()
isNumber()
would return true) AND its value fits
within Java's 32-bit signed integer type, int
.
Note that floating-point numbers are convertible if the integral
part fits without overflow (as per standard Java coercion rules)
NOTE: this method does not consider possible value type conversion
from JSON String into Number; so even if this method returns false,
it is possible that asInt()
could still succeed
if node is a JSON String representing integral number, or boolean.
public boolean canConvertToLong()
isNumber()
would return true) AND its value fits
within Java's 64-bit signed integer type, long
.
Note that floating-point numbers are convertible if the integral
part fits without overflow (as per standard Java coercion rules)
NOTE: this method does not consider possible value type conversion
from JSON String into Number; so even if this method returns false,
it is possible that asLong()
could still succeed
if node is a JSON String representing integral number, or boolean.
public boolean canConvertToExactIntegral()
isNumber()
) and
can be losslessly converted to integral number (specifically,
BigInteger
but potentially others, see
canConvertToInt()
and canConvertToInt()
).
Latter part allows floating-point numbers
(for which isFloatingPointNumber()
returns true
)
that do not have fractional part.
Note that "not-a-number" values of double
and float
will return false
as they can not be converted to matching
integral representations.public String textValue()
isTextual()
returns
false) null will be returned.
For String values, null is never returned (but empty Strings may be)public byte[] binaryValue() throws IOException
isBinary()
returns true); or for Text Nodes
(ones for which textValue()
returns non-null value),
to read decoded base64 data.
For other types of nodes, returns null.IOException
public boolean booleanValue()
public Number numberValue()
isNumber()
returns true); otherwise
returns nullpublic short shortValue()
isNumber()
returns true). For other
types returns 0.
For floating-point numbers, value is truncated using default
Java coercion, similar to how cast from double to short operates.public int intValue()
isNumber()
returns true). For other
types returns 0.
For floating-point numbers, value is truncated using default
Java coercion, similar to how cast from double to int operates.public long longValue()
isNumber()
returns true). For other
types returns 0.
For floating-point numbers, value is truncated using default
Java coercion, similar to how cast from double to long operates.public float floatValue()
isNumber()
returns true). For other
types returns 0.0.
For integer values, conversion is done using coercion; this means
that an overflow is possible for `long` valuespublic double doubleValue()
isNumber()
returns true). For other
types returns 0.0.
For integer values, conversion is done using coercion; this may result
in overflows with BigInteger
values.public BigDecimal decimalValue()
BigDecimal
), if and only if
this node is numeric (isNumber()
returns true). For other
types returns BigDecimal.ZERO
.BigDecimal
value this node contains, if numeric node; BigDecimal.ZERO
for non-number nodes.public BigInteger bigIntegerValue()
BigInteger
), if and only if
this node is numeric (isNumber()
returns true). For other
types returns BigInteger.ZERO
.
NOTE: In Jackson 2.x MAY throw StreamConstraintsException
if the scale of the underlying BigDecimal
is too large to convert (NOTE: thrown
"sneakily" in Jackson 2.x due to API compatibility restrictions)
BigInteger
value this node contains, if numeric node; BigInteger.ZERO
for non-number nodes.public abstract String asText()
isValueNode()
returns true),
otherwise empty String.public String asText(String defaultValue)
defaultValue
if this node
does not have a text value. Useful for nodes that are MissingNode
or
NullNode
, ensuring a default value is returned instead of null or missing indicators.
NOTE: This was deprecated in 2.17.0, but as discussed through [databind#4471], was un-deprecated in 2.17.1.
defaultValue
- The default value to return if this node's text value is absent.public int asInt()
If representation cannot be converted to an int (including structured types like Objects and Arrays), default value of 0 will be returned; no exceptions are thrown.
public int asInt(int defaultValue)
If representation cannot be converted to an int (including structured types like Objects and Arrays), specified defaultValue will be returned; no exceptions are thrown.
public long asLong()
If representation cannot be converted to a long (including structured types like Objects and Arrays), default value of 0 will be returned; no exceptions are thrown.
public long asLong(long defaultValue)
If representation cannot be converted to a long (including structured types like Objects and Arrays), specified defaultValue will be returned; no exceptions are thrown.
public double asDouble()
If representation cannot be converted to an int (including structured types like Objects and Arrays), default value of 0.0 will be returned; no exceptions are thrown.
public double asDouble(double defaultValue)
If representation cannot be converted to an int (including structured types like Objects and Arrays), specified defaultValue will be returned; no exceptions are thrown.
public boolean asBoolean()
If representation cannot be converted to a boolean value (including structured types like Objects and Arrays), default value of false will be returned; no exceptions are thrown.
public boolean asBoolean(boolean defaultValue)
If representation cannot be converted to a boolean value (including structured types like Objects and Arrays), specified defaultValue will be returned; no exceptions are thrown.
public <T extends JsonNode> T require() throws IllegalArgumentException
this
node is NOT so-called
"missing node": that is, one for which isMissingNode()
returns true
.
If not missing node, this
is returned to allow chaining; otherwise
IllegalArgumentException
is thrown.this
node to allow chainingIllegalArgumentException
- if this node is "missing node"public <T extends JsonNode> T requireNonNull() throws IllegalArgumentException
this
node is neither so-called
"missing node" (that is, one for which isMissingNode()
returns true
)
nor "null node" (one for which isNull()
returns true
).
If non-null non-missing node, this
is returned to allow chaining; otherwise
IllegalArgumentException
is thrown.this
node to allow chainingIllegalArgumentException
- if this node is either "missing node" or "null node"public JsonNode required(String propertyName) throws IllegalArgumentException
path(fieldName).required()
and can be used to check that this node is an ObjectNode
(that is, represents
JSON Object value) and has value for specified property with key fieldName
(but note that value may be explicit JSON null value).
If this node is Object Node and has value for specified property, matching value
is returned; otherwise IllegalArgumentException
is thrown.propertyName
- Name of property to accessIllegalArgumentException
- if this node is not an Object node or if it does not
have value for specified propertypublic JsonNode required(int index) throws IllegalArgumentException
path(index).required()
and can be used to check that this node is an ArrayNode
(that is, represents
JSON Array value) and has value for specified index
(but note that value may be explicit JSON null value).
If this node is Array Node and has value for specified index, value at index
is returned; otherwise IllegalArgumentException
is thrown.index
- Index of the value of this Array node to accessIllegalArgumentException
- if this node is not an Array node or if it does not
have value for specified indexpublic JsonNode requiredAt(String pathExpr) throws IllegalArgumentException
at(pathExpr).required()
and can be used to check that there is an actual value node at specified JsonPointer
starting from this
node
(but note that value may be explicit JSON null value).
If such value node exists it is returned;
otherwise IllegalArgumentException
is thrown.pathExpr
- JsonPointer
expression (as String) to use for finding value nodeIllegalArgumentException
- if no value node exists at given JSON Pointer
pathpublic final JsonNode requiredAt(com.fasterxml.jackson.core.JsonPointer path) throws IllegalArgumentException
at(path).required()
and can be used to check that there is an actual value node at specified JsonPointer
starting from this
node
(but note that value may be explicit JSON null value).
If such value node exists it is returned;
otherwise IllegalArgumentException
is thrown.path
- JsonPointer
expression to use for finding value nodeIllegalArgumentException
- if no value node exists at given JSON Pointer
pathpublic boolean has(String fieldName)
This method is equivalent to:
node.get(fieldName) != null(since return value of get() is node, not value node contains)
NOTE: when explicit null
values are added, this
method will return true
for such properties.
fieldName
- Name of element to checkpublic boolean has(int index)
Note: array element indexes are 0-based.
This method is equivalent to:
node.get(index) != null
NOTE: this method will return true
for explicitly added
null values.
index
- Index to checkpublic boolean hasNonNull(String fieldName)
has(String)
, but that will
return false
for explicitly added nulls.
This method is functionally equivalent to:
node.get(fieldName) != null && !node.get(fieldName).isNull()
public boolean hasNonNull(int index)
has(int)
, but that will
return false
for explicitly added nulls.
This method is equivalent to:
node.get(index) != null && !node.get(index).isNull()
public final Iterator<JsonNode> iterator()
elements()
; implemented so that
convenience "for-each" loop can be used for looping over elements
of JSON Array constructs.public Iterator<JsonNode> elements()
public Iterator<Map.Entry<String,JsonNode>> fields()
public Set<Map.Entry<String,JsonNode>> properties()
ObjectNode
similar to how Map.entrySet()
works;
for other node types will return empty Set
.ObjectNode
(isObject()
returns true
); empty
Set
otherwise.public abstract JsonNode findValue(String fieldName)
Note that traversal is done in document order (that is, order in which
nodes are iterated if using elements()
)
fieldName
- Name of field to look forpublic final List<JsonNode> findValues(String fieldName)
List
.
Note that sub-tree search ends when matching field is found,
so possible children of result nodes are not included.
If no matching fields are found in this node or its descendants, returns
an empty List.fieldName
- Name of field to look forpublic final List<String> findValuesAsText(String fieldName)
findValues(java.lang.String)
, but will additionally convert
values into Strings, calling asText()
.public abstract JsonNode findPath(String fieldName)
findValue(java.lang.String)
, but that will return a
"missing node" instead of null if no field is found. Missing node
is a specific kind of node for which isMissingNode()
returns true; and all value access methods return empty or
missing value.fieldName
- Name of field to look forpublic abstract JsonNode findParent(String fieldName)
fieldName
- Name of field to look forpublic final List<JsonNode> findParents(String fieldName)
fieldName
- Name of field to look forpublic abstract List<String> findValuesAsText(String fieldName, List<String> foundSoFar)
public ObjectNode withObject(String exprOrProperty)
exprOrProperty
is a valid JsonPointer
expression or
not (valid expression is either empty String ""
or starts
with leading slash /
character).
If it is, works as a short-cut to:
withObject(JsonPointer.compile(exprOrProperty));If it is NOT a valid
JsonPointer
expression, value is taken
as a literal Object property name and calls is alias for
withObjectProperty(exprOrProperty);
exprOrProperty
- JsonPointer
expression to use (if valid as one),
or, if not (no leading "/"), property name to match.ObjectNode
found or createdpublic final ObjectNode withObject(String expr, JsonNode.OverwriteMode overwriteMode, boolean preferIndex)
withObject(JsonPointer.compile(expr), overwriteMode, preferIndex);
public final ObjectNode withObject(com.fasterxml.jackson.core.JsonPointer ptr)
withObject(JsonPointer, OverwriteMode, boolean)
but
with defaults of OvewriteMode#NULLS
(overwrite mode)
and true
for preferIndex
(that is, will try to
consider JsonPointer
segments index if at all possible
and only secondarily as property nameptr
- JsonPointer
that indicates path to use for Object value to return
(potentially creating as necessary)ObjectNode
found or createdpublic ObjectNode withObject(com.fasterxml.jackson.core.JsonPointer ptr, JsonNode.OverwriteMode overwriteMode, boolean preferIndex)
JsonPointer
, if such a node exists:
or if not, an attempt is made to create one and return it.
For example, on document
{ "a" : { "b" : { "c" : 13 } } }calling method with
JsonPointer
of /a/b
would return
ObjectNode
{ "c" : 13 }
In cases where path leads to "missing" nodes, a path is created.
So, for example, on above document, and
JsonPointer
of /a/x
an empty ObjectNode
would
be returned and the document would look like:
{ "a" : { "b" : { "c" : 13 }, "x" : { } } }Finally, if the path is incompatible with the document -- there is an existing
JsonNode
through which expression cannot go -- a replacement is
attempted if (and only if) conversion is allowed as per overwriteMode
passed in. For example, with above document and expression of /a/b/c
,
conversion is allowed if passing OverwriteMode.SCALARS
or
OvewriteMode.ALL
, and resulting document would look like:
{ "a" : { "b" : { "c" : { } }, "x" : { } } }but if different modes (
NONE
or NULLS
) is passed, an exception
is thrown instead.ptr
- Pointer that indicates path to use for ObjectNode
value to return
(potentially creating one as necessary)overwriteMode
- Defines which node types may be converted in case of
incompatible JsonPointer
expression: if conversion not allowed,
UnsupportedOperationException
is thrown.preferIndex
- When creating a path (for empty or replacement), and path
contains segment that may be an array index (simple integer number like
3
), whether to construct an ArrayNode
(true
) or
ObjectNode
(false
). In latter case matching property with
quoted number (like "3"
) is used within Object.ObjectNode
found or createdUnsupportedOperationException
- if a conversion would be needed for given
JsonPointer
, document, but was not allowed for the type encounteredpublic ObjectNode withObjectProperty(String propName)
withObject(JsonPointer, OverwriteMode, boolean)
-- basically
short-cut to:
withObject(JsonPointer.compile("/"+propName), OverwriteMode.NULLS, false);that is, only matches immediate property on
ObjectNode
and will either use an existing ObjectNode
that is
value of the property, or create one if no value or value is NullNode
.
ObjectNode
NullNode
(explicit null
)
propName
- Name of property that has or will have ObjectNode
as valueObjectNode
value of given property (existing or created)@Deprecated public <T extends JsonNode> T with(String exprOrProperty)
withObject(String)
insteadexprOrProperty
is a valid JsonPointer
expression or
not (valid expression is either empty String ""
or starts
with leading slash /
character).
If it is, works as a short-cut to:
withObject(JsonPointer.compile(exprOrProperty));If it is NOT a valid
JsonPointer
expression, value is taken
as a literal Object property name and traversed like a single-segment
JsonPointer
.
NOTE: before Jackson 2.14 behavior was always that of non-expression usage;
that is, exprOrProperty
was always considered as a simple property name.
public <T extends JsonNode> T withArray(String exprOrProperty)
exprOrProperty
is a valid JsonPointer
expression or
not (valid expression is either empty String ""
or starts
with leading slash /
character).
If it is, works as a short-cut to:
withObject(JsonPointer.compile(exprOrProperty));If it is NOT a valid
JsonPointer
expression, value is taken
as a literal Object property name and traversed like a single-segment
JsonPointer
.
NOTE: before Jackson 2.14 behavior was always that of non-expression usage;
that is, exprOrProperty
was always considered as a simple property name.
public ArrayNode withArray(String expr, JsonNode.OverwriteMode overwriteMode, boolean preferIndex)
withArray(JsonPointer.compile(expr), overwriteMode, preferIndex);
public final ArrayNode withArray(com.fasterxml.jackson.core.JsonPointer ptr)
withArray(JsonPointer, OverwriteMode, boolean)
but
with defaults of OvewriteMode#NULLS
(overwrite mode)
and true
for preferIndex
.public ArrayNode withArray(com.fasterxml.jackson.core.JsonPointer ptr, JsonNode.OverwriteMode overwriteMode, boolean preferIndex)
JsonPointer
, if such a node exists:
or if not, an attempt is made to create one and return it.
For example, on document
{ "a" : { "b" : [ 1, 2 ] } }calling method with
JsonPointer
of /a/b
would return
Array
[ 1, 2 ]
In cases where path leads to "missing" nodes, a path is created.
So, for example, on above document, and
JsonPointer
of /a/x
an empty ArrayNode
would
be returned and the document would look like:
{ "a" : { "b" : [ 1, 2 ], "x" : [ ] } }Finally, if the path is incompatible with the document -- there is an existing
JsonNode
through which expression cannot go -- a replacement is
attempted if (and only if) conversion is allowed as per overwriteMode
passed in. For example, with above document and expression of /a/b/0
,
conversion is allowed if passing OverwriteMode.SCALARS
or
OvewriteMode.ALL
, and resulting document would look like:
{ "a" : { "b" : [ [ ], 2 ], "x" : [ ] } }but if different modes (
NONE
or NULLS
) is passed, an exception
is thrown instead.ptr
- Pointer that indicates path to use for ArrayNode
value to return
(potentially creating it as necessary)overwriteMode
- Defines which node types may be converted in case of
incompatible JsonPointer
expression: if conversion not allowed,
an exception is thrown.preferIndex
- When creating a path (for empty or replacement), and path
contains segment that may be an array index (simple integer number like
3
), whether to construct an ArrayNode
(true
) or
ObjectNode
(false
). In latter case matching property with
quoted number (like "3"
) is used within Object.ArrayNode
found or createdUnsupportedOperationException
- if a conversion would be needed for given
JsonPointer
, document, but was not allowed for the type encounteredpublic ArrayNode withArrayProperty(String propName)
withArray(JsonPointer, OverwriteMode, boolean)
-- basically
short-cut to:
withArray(JsonPointer.compile("/"+propName), OverwriteMode.NULLS, false);that is, only matches immediate property on
ObjectNode
and will either use an existing ArrayNode
that is
value of the property, or create one if no value or value is NullNode
.
ObjectNode
NullNode
(explicit null
)
public boolean equals(Comparator<JsonNode> comparator, JsonNode other)
Comparator
object. Nodes will handle traversal of structured
types (arrays, objects), but defer to comparator for scalar value
comparisons. If a "natural" Comparator
is passed -- one that
simply calls equals()
on one of arguments, passing the other
-- implementation is the same as directly calling equals()
on node.
Default implementation simply delegates to passed in comparator
,
with this
as the first argument, and other
as
the second argument.
comparator
- Object called to compare two scalar JsonNode
instances, and return either 0 (are equals) or non-zero (not equal)public abstract String toString()
ObjectMapper
or ObjectWriter
to serialize an
instance, for example:
String json = objectMapper.writeValueAsString(rootNode);
Note: method defined as abstract to ensure all implementation
classes explicitly implement method, instead of relying
on Object.toString()
definition.
public String toPrettyString()
toString()
that will serialize this node using
Jackson default pretty-printer.public abstract boolean equals(Object o)
Note: marked as abstract to ensure all implementation
classes define it properly and not rely on definition
from Object
.
protected <T extends JsonNode> T _this()
protected <T> T _reportRequiredViolation(String msgTemplate, Object... args)
IllegalArgumentException
as a result of
violating "required-constraint" for this node (for required(java.lang.String)
or related
methods).Copyright © 2008–2024 FasterXML. All rights reserved.