BSON a Extended JSON

Acerca de BSON

¿Qué es BSON?

BSON es el formato binario de serialización de documentos de MongoDB. Guarda documentos con forma de JSON y valores tipados como ObjectId, fechas, datos binarios, expresiones regulares, timestamps y enteros de 64 bits.

¿Cuándo usar BSON?

Usa BSON para inspeccionar documentos MongoDB, probar payloads de drivers, depurar Extended JSON o mover documentos tipados entre sistemas que ya usan el modelo BSON de MongoDB.

BSON en JavaScript

import { deserialize, EJSON, serialize } from 'bson';

const value = EJSON.deserialize({ hello: 'world' });
const bytes = serialize(value);
const hex = Array.from(bytes, (byte) => byte.toString(16).padStart(2, '0')).join('');

console.log(hex);
// Output: 160000000268656c6c6f0006000000776f726c640000

console.log(EJSON.stringify(deserialize(bytes), { relaxed: false }, 2));
				

BSON en Go

package main

import (
	"fmt"

	"go.mongodb.org/mongo-driver/bson"
)

func main() {
	value := bson.D{{Key: "hello", Value: "world"}}
	encoded, _ := bson.Marshal(value)
	fmt.Printf("%x\n", encoded)
	// Output: 160000000268656c6c6f0006000000776f726c640000

	var decoded bson.M
	_ = bson.Unmarshal(encoded, &decoded)
	fmt.Println(decoded["hello"])
	// Output: world
}
				

BSON en PHP

<?php
$value = ['hello' => 'world'];
$encoded = MongoDB\BSON\fromPHP($value);
echo bin2hex($encoded) . PHP_EOL;
// Output: 160000000268656c6c6f0006000000776f726c640000

$decoded = MongoDB\BSON\toPHP($encoded);
echo $decoded->hello . PHP_EOL;
// Output: world