Jsonpickle

Latest version: v4.0.5

Safety actively analyzes 723929 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 5 of 10

1.5.0

Not secure
======
* Previous versions of jsonpickle with `make_refs=False` would emit
``null`` when encountering an object it had already seen when
traversing objects. All instances of the object are now serialized.
While this is arguably an improvement in the vast majority of
scenarios, it is a change in behavior and is thus considered a
minor-level change. (333) (334) (337) (+338)
* Multiple enums are now serialized correctly with `make_refs=False`. (235)

1.4.2

Not secure
======
* Use importlib.metadata from the stdlib on Python 3.8. (+305) (303)
* Micro-optimize type checks to use a `set` for lookups. (+327)
* Documentation improvements.

1.4.1

Not secure
======
* Patch release for Python 3.8 `importlib_metadata` support.
(300)

1.4

Not secure
====
* Python 3.8 support. (292)
* ``jsonpickle.encode`` now supports the standard ``indent``
and ``separators`` arguments, and passes them through to the
active JSON backend library. (183)
* We now include a custom handler for `array.array` objects. (199)
* Dict key order is preserved when pickling dictionaries on Python3. (193)
* Improved serialization of dictionaries with non-string keys.
Previously, using an enum that was both the key and a value in
a dictionary could end up with incorrect references to other
objects. The references are now properly maintained for dicts
with object keys that are also referenced in the dict's values. (286)
* Improved serialization of pandas.Series objects. (287)

1.3

Not secure
====
* Improved round tripping of default dicts. (+283) (282)

* Better support for cyclical references when encoding with
``unpicklable=False``. (+264)

1.2

Not secure
====
* Simplified JSON representation for `__reduce__` values. (+261)

* Improved Pandas support with new handlers for more Pandas data types.
(+256)

* Prevent stack overflows caused by bugs in user-defined `__getstate__`
functions which cause infinite recursion. (+260)
(259)

* Improved support for objects that contain dicts with Integer keys.
Previously, jsonpickle could not restore objects that contained
dicts with integer keys and provided getstate only.
These objects are now handled robustly. (247).

* Support for encoding binary data in `base85`_ instead of base64 has been
added on Python 3. Base85 produces payloads about 10% smaller than base64,
albeit at the cost of lower throughput. For performance and backwards
compatibility with Python 2 the pickler uses base64 by default, but it can
be configured to use ``base85`` with the new ``use_base85`` argument.
(251).

* Dynamic SQLAlchemy tables in SQLAlchemy >= 1.3 are now supported.
(254).

.. _base85: https://en.wikipedia.org/wiki/Ascii85

Page 5 of 10

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.