Szukaj…


Składnia

  • serializować (obiekt $)
  • unserialize ($ object)

Uwagi

Wszystkie typy PHP oprócz zasobów są serializowane. Zasoby to unikalny typ zmiennej, który odwołuje się do źródeł „zewnętrznych”, takich jak połączenia z bazą danych.

Serialize / Unserialize

serialize() zwraca ciąg zawierający bajtową reprezentację dowolnej wartości, która może być przechowywana w PHP. unserialize() może użyć tego ciągu do odtworzenia oryginalnych wartości zmiennych.

Aby serializować obiekt

serialize($object);

Aby odserializować obiekt

unserialize($object)

Przykład

$array = array();
$array["a"] = "Foo";
$array["b"] = "Bar";
$array["c"] = "Baz";
$array["d"] = "Wom";

$serializedArray = serialize($array);
echo $serializedArray; //output: a:4:{s:1:"a";s:3:"Foo";s:1:"b";s:3:"Bar";s:1:"c";s:3:"Baz";s:1:"d";s:3:"Wom";}

Interfejs do szeregowania

Wprowadzenie

Klasy implementujące ten interfejs nie obsługują już __sleep() i __wakeup() . Metoda serializacji jest wywoływana za każdym razem, gdy wystąpienie wymaga serializacji. Nie wywołuje to __destruct() ani nie wywołuje żadnych innych skutków ubocznych, chyba że jest zaprogramowany w metodzie. Gdy dane nie unserialized klasa jest znana, a odpowiednia metoda unserialize() jest wywoływana jako konstruktor zamiast wywoływania __construct() . Jeśli potrzebujesz uruchomić standardowego konstruktora, możesz to zrobić w metodzie.

Podstawowe użycie

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); // Output: string(38) "C:3:"obj":23:{s:15:"My private data";}"

$newobj = unserialize($ser);

var_dump($newobj->getData()); // Output: string(15) "My private data"


Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow