A lightweight and strict PHP implementation of the JSON Canonicalization Scheme (JCS) according to RFC 8785.
JSON Canonicalization Scheme (RFC 8785) defines a standard way to serialize JSON data so that logically equivalent data produces identical byte-by-byte output. This is essential for creating digital signatures, hashing JSON payloads, or safely comparing JSON documents.
Key rules of JCS:
- Object properties are sorted lexicographically by their byte values.
- Whitespace between tokens is removed.
- Numbers are serialized in a strict format without trailing zeros.
For this package to correctly serialize floating-point numbers according to the RFC requirements, your php.ini must have the serialize_precision directive set to -1.
Check your php.ini file:
serialize_precision = -1Note: In modern PHP versions (7.1+), -1 is usually the default value, which ensures floats are encoded accurately.
You can install the package via Composer:
composer require truschery/kanonPass your array or object to the canonicalizer to get the RFC 8785 compliant JSON string.
use Truschery\Kanon\Json;
// Unordered array with different data types
$data =[
'z' => 123.456,
'a' => 'test',
'b' =>[
'foo' => 'bar',
'baz' => 100
]
];
$canonicalJson = Json::canonicalize($data);
echo $canonicalJson;
// Output (keys sorted, no spaces):
// {"a":"test","b":{"baz":100,"foo":"bar"},"z":123.456}This package comes with a test suite to ensure strict compliance with the specification. To run the tests, use:
composer test
# or directly:
./vendor/bin/phpunitThe MIT License (MIT). Please see License File for more information.