Método __serialize
El método mágico __serialize se llama al serializar un objeto
con la función serialize. Debe devolver un array de datos que
serán serializados. Este método apareció en PHP 7.4 como alternativa
al método __sleep con un control más flexible del proceso de serialización.
Sintaxis
public function __serialize(): array
Ejemplo
Creemos una clase con el método __serialize que definirá
qué propiedades del objeto necesitan ser serializadas:
<?php
class User {
public $name;
private $password;
public $email;
public function __construct($name, $password, $email) {
$this->name = $name;
$this->password = $password;
$this->email = $email;
}
public function __serialize(): array {
return [
'name' => $this->name,
'email' => $this->email,
'hash' => md5($this->password)
];
}
}
$user = new User('John', 'secret123', 'john@example.com');
echo serialize($user);
?>
Resultado de la ejecución del código:
'O:4:"User":3:{s:4:"name";s:4:"John";s:5:"email";s:15:"john@example.com";s:4:"hash";s:32:"e5e9fa1ba31ecd1ae84f75caaa474f3a";}'
Ejemplo
Demostremos la diferencia entre __serialize y __sleep:
<?php
class Product {
public $id;
protected $price;
private $discount;
public function __sleep() {
return ['id', 'price'];
}
public function __serialize(): array {
return [
'id' => $this->id,
'price' => $this->price * (1 - $this->discount)
];
}
}
$product = new Product();
$product->id = 100;
$product->price = 50;
$product->discount = 0.1;
echo "Sleep: " . serialize($product) . "\n";
echo "Serialize: " . serialize($product);
?>
Resultado de la ejecución del código:
'Sleep: O:7:"Product":2:{s:2:"id";i:100;s:5:"price";i:50;}'
'Serialize: O:7:"Product":2:{s:2:"id";i:100;s:5:"price";d:45;}'
Ver también
-
la función
serialize,
que convierte un valor en una cadena almacenable