-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Jackson Release 2.18
Jackson Version 2.18 was released on September 26, 2024. One release candidate (2.18.0-rc1) was released prior to final 2.18.0.
This wiki page gives a list of links to all changes (with brief descriptions) that will be included, as well as about original plans for bigger changes (and in some cases changes to plans, postponing).
Branch is open for patch releases.
Same as Jackson 2.17, SDK 26
Same as Jackson 2.17
Kotlin 1.7.x no longer supported (1.8, 1.9, 2.0 are): kotlin#803
JAX-RS Provider will once again support JAX-RS 1.x as per:
- #192: Bring back code to support JAXRS v1 (revert #134 for 2.18)
where support had been earlier removed from Jackson 2.13. Support will not continue to 3.0 but is now planned to continue for the rest of 2.x series
As per:
- Avro#167: Incompatibility with Avro >=1.9.0 (upgrade to Avro 1.11.3)
Avro module now depends on Apache Avro library 1.11.3 (instead of 1.8.2). Update should not affect wire-compatibility, but:
- It is important to ensure that the transitive dependency to
org.apache.avro:avro
has correct version (1.11.3 or higher; but at minimum 1.9.x) - Avro schemas generated with Jackson 2.18 for classes with multiple nesting levels cannot be read with older versions of Jackson Avro module (see issue above for details)
- Has been on top spot of priority lists since at least 2.8 (mentioned in release notes) -- 8 years ago!!!
-
databind#4515 -- fully rewritten POJO (including Record) Property Introspection
- Solved 5 previously failing unit tests:
- (only for 3.0) databind#538: Injection when there is cyclic references fails
-
databind#806: Problem with
NamingStrategy
, creator methods with implicit names -
databind#2977: Incompatible
FAIL_ON_MISSING_PRIMITIVE_PROPERTIES
and field level@JsonProperty
-
databind#3241:
constructorDetector
seems to invalidatedefaultSetterInfo
for nullability -
databind#4119: Exception when deserialization uses a record with a constructor property with
access=READ_ONLY
- Solved 5 previously failing unit tests:
-
databind#562: Allow
@JsonAnySetter
to flow through Creators
- More optimized
JsonParser.getFloatValue()
/JsonParser.getDoubleValue()
: avoidString
creation when callingFastDoubleParser
:
Following features were considered for implementation but did not get implemented for this version
-
databind#512: Add
@JsonWrapped
- Matching annotations issue: annotations#42
- No changes since 2.17
-
#223:
UTF8JsonGenerator
writes supplementary characters as a surrogate pair -- should use 4-byte encoding -
#1230: Improve performance of
float
anddouble
parsing fromTextBuffer
-
#1251: InternCache - replace synchronized with
ReentrantLock
-
#1252:
ThreadLocalBufferManager
replace synchronized withReentrantLock
- #1257: Increase InternCache default max size from 100 to 200
- #1262: Add diagnostic method pooledCount() in RecyclerPool
-
#1264: Rename shaded
ch.randelshofer:fastdoubleparser
classes to prevent use by downstream consumers -
#1271: Deprecate
LockFreePool
implementation in 2.18 (remove from 3.0) -
#1274:
NUL
-corrupted keys, values on JSON serialization -
#1277: Add back Java 22 optimisation in
FastDoubleParser
-
#1284: Optimize
JsonParser.getDoubleValue()/getFloatValue()/getDecimalValue()
to avoid String allocation -
#1310: Add new
StreamReadConstraints
(maxTokenCount
) to limit maximum number of Tokens allowed per document -
#1331: Update to FastDoubleParser v1.0.1 to fix
BigDecimal
decoding problem -
#1340: Missing
JsonFactory
"provides" SPI with JPMS injackson-core
module
-
#562: Allow
@JsonAnySetter
to flow through Creators -
#806: Problem with
NamingStrategy
, creator methods with implicit names -
#2977: Incompatible
FAIL_ON_MISSING_PRIMITIVE_PROPERTIES
and field level@JsonProperty
-
#3241:
constructorDetector
seems to invalidatedefaultSetterInfo
for nullability -
#3439: Java Record
@JsonAnySetter
value is null after deserialization -
#4119: Exception when deserialization uses a record with a constructor property with
access=READ_ONLY
-
#4356:
BeanDeserializerModifier::updateBuilder()
doesn't work for beans with Creator methods -
#4407:
null
type id handling does not work withwriteTypePrefix()
-
#4452:
@JsonProperty
not serializing field names properly on@JsonCreator
in Record -
#4453: Allow JSON Integer to deserialize into a single-arg constructor of parameter type
double
-
#4456: Rework locking in
DeserializerCache
-
#4458: Rework synchronized block from
BeanDeserializerBase
-
#4464: When
Include.NON_DEFAULT
setting is used,isEmpty()
method is not called on the serializer -
#4472: Rework synchronized block in
TypeDeserializerBase
-
#4483: Remove
final
on method BeanSerializer.serialize() - #4515: Rewrite Bean Property Introspection logic in Jackson 2.x
-
#4570: Deprecate
ObjectMapper.canDeserialize()
/ObjectMapper.canSerialize()
-
#4580: Add
MapperFeature.SORT_CREATOR_PROPERTIES_BY_DECLARATION_ORDER
to use Creator properties' declaration order for sorting - #4584: Provide extension point for detecting "primary" Constructor for Kotlin (and similar) data classes
-
#4602: Possible wrong use of _arrayDelegateDeserializer in
BeanDeserializerBase::deserializeFromObjectUsingNonDefault()
- #4617: Record property serialization order not preserved
-
#4634:
@JsonAnySetter
not working when annotated on both constructor parameter & field -
#4678: Java records don't serialize with
MapperFeature.REQUIRE_SETTERS_FOR_GETTERS
since 2.16 -
#4688: Should allow deserializing with no-arg
@JsonCreator(mode = DELEGATING)
-
#4699: Add extra
writeNumber()
method inTokenBuffer
-
#4709: Add
JacksonCollectors
withtoArrayNode()
implementation
- #167: Incompatibility with Avro >=1.9.0 (upgrade to Avro 1.11.3)
- #494: Avro Schema generation: allow mapping Java Enum properties to Avro String values
-
#508: Ignore
specificData
field on serialization
-
#442: Allow use of "value decorators" (like
[
and]
for arrays) for readingCsvSchema
columns -
#468: Remove synchronization from
CsvMapper
-
#469: Allow CSV to differentiate between
null
and empty fields (foo,,bar vs. foo,"",bar) - #483: Incorrect location of CSV errors
- #485: CSVDecoder: No Long and Int out of range exceptions
-
#495: Support use of
CsvValueDecorator
for writing CSV column values
- #509: IonValueMapper.builder() not implemented, does not register modules
-
#484: Rework synchronization in
ProtobufMapper
-
#482: Allow passing
ParserImpl
by a subclass or overwrite the events
- #160: Defect wrt guava OSGi dependency version specified
- #248: jClass annotations and polymorphic types are ignored when deserializing Android Record fields
- #251: Constructor is not recognized when a record uses both arrays and generic types
- #233: Tolerate JAX-RS 2.2 in jackson-module-jaxb-annotations so that it can be deployed in Liberty alongside features which use 2.2
- #542: Remove meaningless checks and properties in KNAI.
-
#782: Content marked as deprecated has been reorganized. Several constructors and accessors to properties of KotlinModule.Builder that were marked as
DeprecationLevel.ERROR
have been removed. Also, the content marked as DeprecationLevel.WARNING is now DeprecationLevel.ERROR. - #803: Update Kotlin version; remove support for 1.7
- #817: The convertValue extension function now accepts null
-
#818: The implementation of the search process for the
JsonCreator
(often the primary constructor) used by default for deserialization has been changed toAnnotationIntrospector#findDefaultCreator
. This has improved first-time processing performance and memory usage. It also solves the problem offindCreatorAnnotation
results byAnnotationIntrospector
registered by the user being ignored depending on the order in which modules are registered.
There are no new fixes in this release.
- #192: Bring back code to support JAXRS v1 (revert #134 for 2.18)
- #193: JacksonJsonProvider has @Produces(MediaType.WILDCARD) and yet hasMatchingMediaType(MediaType.WILDCARD) return false
-
#30:
JacksonJsonProvider
has @Produces(MediaType.WILDCARD) and yet hasMatchingMediaType(MediaType.WILDCARD) return false
- #162: Add support for deserializing Java Records