-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Jackson Release 2.15
Jackson Version 2.15 was released on April 23, 2023. Three release candidates (2.15.0-rc1, -rc2 and -rc3) were released prior to the final 2.15.0.
This wiki page gives a list of links to all changes (with brief descriptions) that are included, as well as about original plans for bigger changes (and in some cases changes to plans, postponing).
Branch is open (as of April 2023) and new patch releases are expected.
- 2.15.1 (not yet released)
- Jackson 2.15 floating-point read performance improvements
- Jackson 2.15 floating-point write performance improvements
Same as Jackson 2.14
Jackson 2.15 no longer supports Kotlin 1.4 -- supported versions are 1.5 - 1.8
As per YAML#390 SnakeYAML
dependency upgrade to Snakeyaml 2.0 from 1.33, to resolve CVE-2022-1471.
Despite seeming major version upgrade, should NOT affect compatibility of Jackson YAML format module -- SnakeYAML version scheme only uses 2 digits so this is more like a minor version upgrade, affecting API that Jackson does not use. Jackson YAML module will still work with older version of SnakeYAML (such as 1.33) so if necessary, users can forcible downgrade it if necessary for compatibility reasons with other libraries, frameworks.
Default/baseline Guava dependency now 23.6.1-jre
(was 21.0
in 2.14), but module still works with full range of Guava versions from 14.0
to the latest (31.1-jre
as of writing this)
- Hibernate module build now requires JDK 11 (due to Hibernate 6 module)
- jackson-core is now a Multi-Release jar to support more optimal handling for newer JDKs wrt number parsing.
2.15 adds maximum token limits for different tokens as described below. All limits are:
- Expressed in input units --
byte
s orchar
s -- depending on input source - Defined as longest allowed length, but not necessarily imposed at 100% accuracy: that is, if maximum allowed length is specified as 1000 units, something with length of, say 1003 may not cause exception (but 1500 would)
- Defined in new
StreamReadConstraints
class, configurable on per-JsonFactory
basis
Implementation of jackson-core#827 sets up upper limit on maximum length of numeric tokens read from input. Default limit is:
- Maximum 1000 for both integral and floating-point numbers.
Note that dataformat modules need to add support for enforcing the limits so coverage may vary: as usual, JSON parser will have the widest coverage initially.
Implementation of jackson-core#863 sets up upper limit on maximum length of String values read from input. Default limit is:
- Maximum of 5_000_000 (5 million) input units (bytes/chars depending on input source)
- Java 8 Date/Time handling:
- https://github.com/FasterXML/jackson-modules-java8/pull/267: Normalize zone id during ZonedDateTime deserialization
- Implemented limits -- as explained earlier -- for
Use of FastDoubleParser library in more places, more widely (2.14 already used it in some places) may yield incremental performance improvements. Also uses the latest release of FDP.
-
#2667: Add
@EnumNaming
,EnumNamingStrategy
to allow use of naming strategies for Enums -
#2968: Deserialization of
@JsonTypeInfo
annotated type fails with missing type id even for explicit concrete subtypes
-
#211: Add
JsonFormat.Feature
s: READ_UNKNOWN_ENUM_VALUES_AS_NULL, READ_UNKNOWN_ENUM_VALUES_USING_DEFAULT_VALUE - #214: Add NOTICE file with copyright information
-
#221: Add
JsonFormat.Feature.READ_DATE_TIMESTAMPS_AS_NANOSECONDS
-
#827: Add numeric value size limits via
StreamReadConstraints
(fixessonatype-2022-6438
) - #844: Add SLSA provenance via build script
-
#851: Add
StreamReadFeature.USE_FAST_BIG_NUMBER_PARSER
to enable fasterBigDecimal
,BigInteger
parsing -
#863: Add
StreamReadConstraints
limit for longest textual value to allow (default: 5M) - #865: Optimize parsing 19 digit longs
-
#898: Possible flaw in
TokenFilterContext#skipParentChecks()
-
#902: Add
Object JsonParser.getNumberValueDeferred()
method to allow for deferred decoding in some cases -
#921: Add
JsonFactory.Feature.CHARSET_DETECTION
to disable charset detection -
#943: Add
StreamReadConstraints.maxNestingDepth()
to constraint max nesting depth (default: 1000) -
#948: Use
StreamConstraintsException
in name canonicalizers -
#968: Prevent inefficient internal conversion from
BigDecimal
toBigInteger
wrt ultra-large scale -
#984: Add
JsonGenerator.copyCurrentEventExact
as alternative tocopyCurrentEvent()
- Build uses package type "jar" but still produces valid OSGi bundle (changed needed to keep class timestamps with Reproducible Build)
-
#2536: Add
EnumFeature.READ_ENUM_KEYS_USING_INDEX
to work with existing "WRITE_ENUM_KEYS_USING_INDEX" -
#2667: Add
@EnumNaming
,EnumNamingStrategy
to allow use of naming strategies for Enums -
#2968: Deserialization of
@JsonTypeInfo
annotated type fails with missing type id even for explicit concrete subtypes -
#2974: Null coercion with
@JsonSetter
does not work withjava.lang.Record
- #2992: Properties naming strategy do not work with Record
-
#3053: Allow serializing enums to lowercase (
EnumFeature.WRITE_ENUMS_TO_LOWERCASE
) -
#3180: Support
@JsonCreator
annotation on record classes -
#3262:
InvalidDefinitionException
when callingmapper.createObjectNode().putPOJO
-
#3297:
@JsonDeserialize(converter = ...)
does not work with Records -
#3342:
JsonTypeInfo.As.EXTERNAL_PROPERTY
does not work with record wrappers - #3352: Do not require the usage of opens in a modular app when using records
-
#3566: Cannot use both
JsonCreator.Mode.DELEGATING
andJsonCreator.Mode.PROPERTIES
static creator factory methods for Enums -
#3637: Add enum features into
@JsonFormat.Feature
- #3638: Case-insensitive and number-based enum deserialization are (unnecessarily) mutually exclusive
-
#3651: Deprecate "exact values" setting from
JsonNodeFactory
, replace withJsonNodeFeature.STRIP_TRAILING_BIGDECIMAL_ZEROES
-
#3654: Infer
@JsonCreator(mode = Mode.DELEGATING)
from use of@JsonValue
) -
#3676: Allow use of
@JsonCreator(mode = Mode.PROPERTIES)
creator for POJOs with "empty String" coercion - #3680: Timestamp in classes inside jar showing 02/01/1980
-
#3682: Transient
Field
s are not ignored as Mutators if there is visible Getter - #3690: Incorrect target type for arrays when disabling coercion
-
#3708: Seems like
java.nio.file.Path
is safe for Android API level 26 -
#3730: Add support in
TokenBuffer
for lazily decoded (big) numbers - #3736: Try to avoid auto-detecting Fields for Record types
-
#3742: schemaType of
LongSerializer
is wrong -
#3745: Deprecate classes in package
com.fasterxml.jackson.databind.jsonschema
-
#3748:
DelegatingDeserializer
missing override ofgetAbsentValue()
(and couple of other methods) - #3771: Classloader leak: DEFAULT_ANNOTATION_INTROSPECTOR holds annotation reference
-
#3791: Flush readonly map together with shared on
SerializerCache.flush()
- #3796: Enum Deserialisation Failing with Polymorphic type validator
-
#3809: Add Stream-friendly alternative to
ObjectNode.fields()
:Set<Map.Entry<String, JsonNode>> properties()
-
#3814: Enhance
StdNodeBasedDeserializer
to supportreaderForUpdating
-
#3816:
TokenBuffer
does not implementwriteString(Reader reader, int len)
-
#3819: Add convenience method
SimpleBeanPropertyFilter.filterOutAll()
as symmetric counterpart ofserializeAll()
-
#3836:
Optional<Boolean>
is not recognized as boolean field -
#3853: Add
MapperFeature.REQUIRE_TYPE_ID_FOR_SUBTYPES
to enable/disable strict subtype Type Id handling -
#3876:
TypeFactory
cache performance degradation withconstructSpecializedType()
-
#347: Add support for CBOR stringref extension (
CBORGenerator.Feature.STRINGREF
) -
#356: Add
CBORGenerator.Feature.WRITE_MINIMAL_DOUBLES
for writingdouble
s asfloat
s if safe to do so -
#373: Remove optimized
CBORParser.nextTextValue()
implementation
- #387: Stack overflow (50083) found by OSS-Fuzz
- #411: Fuzzer-found issue #57237 (buffer boundary condition)
-
#286: Conflict between
@JsonIdentityInfo
and Unwrapped Lists - #533: (Android) java.lang.NoClassDefFoundError: Failed resolution of: Ljavax/xml/stream/XMLInputFactory
-
#542:
XmlMapper
does not find no-argument record constructor for deserialization of empty XML - #547: Parsing empty tags without default no-arguments constructor fails in 2.14
-
#560: Add
DefaultXmlPrettyPrinter.withCustomNewLine()
to configure linefeed for XML pretty-printing -
#578:
XmlMapper
serializes@JsonAppend
property twice -
#584: Deserialization of
null
String values in Arrays /Collection
s not working as expected
-
#373: Positive numbers with plus sign not quoted correctly with
ALWAYS_QUOTE_NUMBERS_AS_STRINGS
-
#388: Add
YAMLParser.Feature.PARSE_BOOLEAN_LIKE_WORDS_AS_STRINGS
to allow parsing "boolean" words as strings instead of booleans - #390: Upgrade to Snakeyaml 2.0 (resolves CVE-2022-1471)
-
#415: Use
LoaderOptions.allowDuplicateKeys
to enforce duplicate key detection
-
#7: Add support for
WRITE_SORTED_MAP_ENTRIES
for GuavaMultimap
s -
#92:
@JsonDeserialize.contentConverter
does not work for non-builtin collections -
#102: accept lowerCase enums for
Range
BoundType
serialization - #105: Update default Guava dependency for Jackson 2.15 from Guava 21.0 to 23.6.1-jre
-
#158: Add
jackson-datatype-hibernate6
for Hibernate 6
- #259: Wrong module auto-registered when using JPMS
-
#266: Optimize
InstantDeserializer
methodreplaceZeroOffsetAsZIfNecessary()
- #267: Normalize zone id during ZonedDateTime deserialization
- #190: Filter annotated by JsonInclude.Include.CUSTOM does not get called if the field is null with Afterburner/Blackbird module registered
- #396: (regression) no default no-arguments constructor found
- #554: Add extension function for addMixin.
- #580: Lazy load UNIT_TYPE
- #627: Merge creator cache for Constructor and Method
- #628: Remove unnecessary cache
- #629: Changed to not cache valueParameters
- #631: Fix minor bugs in SimpleModule.addSerializer/addDeserializer
- #634: Fix ReflectionCache to be serializable
- #641: Fixed is-getter names to match parameters and fields
- #646: Drop Kotlin 1.4 support from Kotlin module 2.15
- #647: Added deprecation to MissingKotlinParameterException
- #654: Change MKPE.parameter property to transient(fixes #572)
-
#170: Add
JaxRsFeature.READ_FULL_STREAM
to consume all content, on by default
-
#16: Add
JakartaRsFeature.READ_FULL_STREAM
to consume all content, on by default