typiqally / binary
PHP Binary Serializer
Requires
- php: ^7.4 || ^8.0
- ext-json: *
Requires (Dev)
- phpunit/phpunit: ^9.4
This package is auto-updated.
Last update: 2025-06-17 18:46:54 UTC
README
This package aims to help create structured models for binary data. For example, this can be used to provide a structured way to (de)serialize incoming and outgoing TCP data or other for other binary related use-cases.
Note
This project is currently under development and still in an alpha stage.
Installation
The package can be installed by executing the following command:
composer require typiqally/binary
Model
Structured binary models are created like this:
use Typiqally\Binary\BinaryModel; class Packet extends BinaryModel { public array $fields = [ //Name => [Type, Expected length], 'magic' => ['raw', 4], 'protocol' => ['numeric', 1], 'length' => ['numeric', 2], ]; }
Usage
When the model is created, serializing is very easy. The constructor is automatically created and can be inherited if required. Just construct your model like this:
$model = new Packet("\x12\x34\x56\x78", 10, 1337);
Serialization
To serialize your model to binary, simply call the following function:
$value = BinarySerializer::serialize($model); //Output (converted to hex using bin2hex): 123456780a0539
Deserialization
To deserialize your binary to a model, you can call the following function:
$model = BinarySerializer::deserialize(Packet::class, $value); //Output (by using the internal __toString function): magic=%124Vx, protocol=10, length=1337
License
This project is licensed under the GPL-3.0 license. See LICENSE.md for the full license text.