CBOR — компактный бинарный формат IETF для сериализации типизированных JSON-подобных данных. Он поддерживает байтовые строки, теги, массивы, словари и целые числа за пределами обычного JSON.
Используйте CBOR для протокольных payload, embedded-систем, подписанных или упакованных данных, а также форматов, которым нужны байтовые строки, семантические теги, нестроковые ключи или детерминированная бинарная сериализация.
import { encode, decode } from 'cbor-x';
const value = { hello: 'world' };
const bytes = encode(value);
const hex = Array.from(bytes, (byte) => byte.toString(16).padStart(2, '0')).join('');
console.log(hex);
// Output: a16568656c6c6f65776f726c64
console.log(decode(bytes));
// Output: { hello: 'world' }
package main
import (
"fmt"
"github.com/fxamacker/cbor/v2"
)
func main() {
value := map[string]any{"hello": "world"}
encoded, _ := cbor.Marshal(value)
fmt.Printf("%x\n", encoded)
// Output: a16568656c6c6f65776f726c64
var decoded map[string]any
_ = cbor.Unmarshal(encoded, &decoded)
fmt.Println(decoded["hello"])
// Output: world
}
<?php
require 'vendor/autoload.php';
use CBOR\Decoder;
use CBOR\MapObject;
use CBOR\StringStream;
use CBOR\TextStringObject;
$value = MapObject::create()
->add(TextStringObject::create('hello'), TextStringObject::create('world'));
$encoded = (string) $value;
echo bin2hex($encoded) . PHP_EOL;
// Output: a16568656c6c6f65776f726c64
$decoded = Decoder::create()->decode(StringStream::create($encoded))->normalize();
echo $decoded['hello'] . PHP_EOL;
// Output: world