CBOR es un formato binario compacto del IETF para serializar datos con forma de JSON y datos tipados. Soporta cadenas de bytes, etiquetas, arrays, diccionarios clave-valor y enteros fuera de los límites normales de JSON.
Usa CBOR para payloads de protocolos, sistemas embebidos, datos firmados o encapsulados y formatos que necesitan cadenas de bytes, etiquetas semánticas, claves no textuales o serialización binaria determinista.
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