| Recommend this page to a friend! | 
|  Download | 
| Info | Documentation |  Files |  Install with Composer |  Download | Reputation | Support forum | Blog | Links | 
| Ratings | Unique User Downloads | Download Rankings | ||||
| Not enough user ratings | Total: 57 | All time:  10,569 This week: 206  | ||||
| Version | License | PHP version | Categories | |||
| oireserializer 1.0 | MIT/X Consortium ... | 5 | PHP 5, Data types | 
| Description | Author | |
| This class can serialize data types in multiple ways. | 
Serializes various data to different formats. There is also a possibility to additionally encode the output to URL-and filename-safe base64. Depends on Oirė Base64 for encoding binary data to a storable format.
Requires PHP 7.1 or later with JSON support enabled. Requires additional PECL extensions for certain serialization modes, see below. If no PECL is available and none of the required extensions is installed in your environment (such a shared hosting), you can freely use Oirė Serializer with JSON.
Via Composer:
composer require oire/serializer
Or manually. Note that you will need base64.php from Oirė Base64:
require_once("oire/base64.php");
require_once("oire/serializer.php");
Run phpunit in the projects directory.
Serialization to JSON. Note that you can either call methods consequently or chain them, like this:
use \Oire\Serializer;
$data = ["fruit" => "orange", "vegetable" => "carrot", "money" => 3000, "randomArray" => [1, 2, 3, 4, 5], "Lambė" => "??????????"];
try {
	// You can pass "j", "json" or 1 to setMode() to get JSON
	$jsonSerialized = (new Serializer())->setMode("json")->serialize($data);
} catch(Exception $e) {
	// Handle errors
}
This will output:
{"fruit":"orange","vegetable":"carrot","money":3000,"randomArray":[1,2,3,4,5],"Lambė":"??????????"}
Now unserializing:
// Without chaining it will be like this
$s = new Serializer();
// You may wrap this also with try...catch
$s->setMode("j");
try {
	$unserialized = $s->unserialize($jsonSerialized);
} catch(Exception $e) {
	// Handle errors
}
This will return the original array. If you want to get an object instead, pass false as the third parameter to unserialize().  
If you pass true as the second parameter to serialize(), the serialized data will be additionally encoded to URL-and filename-safe base64. This might be particularly useful if you choose a binary format such as MessagePack:
$msgPackSerialized = (new Serializer())->setMode("mp")->serialize($data, true);
This will output:
haVmcnVpdKZvcmFuZ2WpdmVnZXRhYmxlpmNhcnJvdKVtb25lec0LuKtyYW5kb21BcnJheZUBAgMEBaZMYW1iw6u00KPQutGA0LDRl9C90YHRjNC60LA
Currently the following modes are supported. Note, if the mode is binary, a raw binary string is returned if $base64 parameter is left as false during serialization which can be uncomfortable for reading or storage.
* JSON, non-binary. Pass 1, "j" or "json" to setMode() to set this mode.
* MessagePack, binary. Pass 2, "m", "mp", "msgpack" or "messagepack" to setMode() to set this mode. Note that the corresponding PECL extension should be installed for this to work.
* Igbinary, binary. Pass 3, "i", "ib", "ig" or "igbinary" to setMode() to set this mode. Note that the corresponding PECL extension should be installed for this to work.
The methods are documented in the source file, but their description is given below.  
We recommend to wrap every call in try...catch since Oirė Serializer throws exceptions in case of errors.
Copyright © 2017, Andre Polykanine also known as Menelion Elensślė. This software is licensed under an MIT license.
|  Files (8) | 
| File | Role | Description | ||
|---|---|---|---|---|
|  src (1 file) | ||||
|  tests (1 file) | ||||
|  .travis.yml | Data | Auxiliary data | ||
|  autoload.php | Aux. | Auxiliary script | ||
|  composer.json | Data | Auxiliary data | ||
|  LICENSE | Lic. | License text | ||
|  phpunit.xml | Data | Auxiliary data | ||
|  README.md | Doc. | Documentation | ||
| The PHP Classes site has supported package installation using the Composer tool since 2013, as you may verify by reading this instructions page. | 
|  Install with Composer | 
|  | oireserializer-2017-06-11.zip 9KB | 
|  | oireserializer-2017-06-11.tar.gz 7KB | 
|  | Install with Composer | 
| Needed packages | ||
| Class | Download | Why it is needed | Dependency | 
|---|---|---|---|
| Oire Base64 |  .zip  .tar.gz | Needed for encoding serialized data to Url-safe base64. | Conditional | 
| Version Control | Unique User Downloads | Download Rankings | |||||||||||||||
| 100% | 
 | 
 | 
| Applications that use this package | 
 If you know an application of this package, send a message to the author to add a link here.
 If you know an application of this package, send a message to the author to add a link here.