The Serializable interface
(PHP 5 >= 5.1.0, PHP 7, PHP 8)
Introdução
Interface para serialização personalizada.
Classes que implementam esta intarface não possuem mais suporte aos métodos __sleep() and __wakeup(). O método serialize é chamado não importando se uma instância possui a necessidade de ser serializada. Não invoca o método __destruct(), ou possui qualquer outro efeito colateral a não ser que programado no método. Quando os dados são deserializados, a classe toma conhecimento e o método unserialize() apropriado é chamado como um construtor, em vez de chamar o método __construct(). Se necessitar executar o construtor padrão, pode-se fazer no método.
A partir do PHP 8.1.0, uma classe que implemente Serializable sem implementar __serialize() e __unserialize() gerará um aviso de descontinuação.
Resumo da Interface
Exemplos
Example #1 Basic usage
<?php
class obj implements Serializable {
private $data;
public function __construct() {
$this->data = "My private data";
}
public function serialize() {
return serialize($this->data);
}
public function unserialize($data) {
$this->data = unserialize($data);
}
public function getData() {
return $this->data;
}
}
$obj = new obj;
$ser = serialize($obj);
var_dump($ser);
$newobj = unserialize($ser);
var_dump($newobj->getData());
?>
O exemplo acima produzirá algo semelhante a:
string(38) "C:3:"obj":23:{s:15:"My private data";}" string(15) "My private data"
Table of Contents
- Serializable::serialize — Representação em string de um objeto
- Serializable::unserialize — Constrói o objeto