MessagePack es un formato binario compacto para serializar datos con forma de JSON, incluidos strings, números, arrays, diccionarios, datos binarios, timestamps y valores de extensión.
Usa MessagePack para payloads de API, entradas de caché, mensajes de cola y logs compactos cuando ambos lados entienden MessagePack y necesitas menos bytes que JSON sin abandonar un modelo de datos similar.
import { encode, decode } from '@msgpack/msgpack';
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: 81a568656c6c6fa5776f726c64
console.log(decode(bytes));
// Output: { hello: 'world' }
package main
import (
"fmt"
"github.com/vmihailenco/msgpack/v5"
)
func main() {
value := map[string]any{"hello": "world"}
encoded, _ := msgpack.Marshal(value)
fmt.Printf("%x\n", encoded)
// Output: 81a568656c6c6fa5776f726c64
var decoded map[string]any
_ = msgpack.Unmarshal(encoded, &decoded)
fmt.Println(decoded["hello"])
// Output: world
}
<?php
require 'vendor/autoload.php';
use MessagePack\MessagePack;
$value = ['hello' => 'world'];
$encoded = MessagePack::pack($value);
echo bin2hex($encoded) . PHP_EOL;
// Output: 81a568656c6c6fa5776f726c64
$decoded = MessagePack::unpack($encoded);
echo $decoded['hello'] . PHP_EOL;
// Output: world