<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/language.oop5.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'pt_BR',
  ),
  'this' => 
  array (
    0 => 'language.oop5.serialization.php',
    1 => 'Serializa&ccedil;&atilde;o de Objetos',
    2 => 'Serializa&ccedil;&atilde;o de Objetos - Objetos em sess&otilde;es',
  ),
  'up' => 
  array (
    0 => 'language.oop5.php',
    1 => 'Classes e Objetos',
  ),
  'prev' => 
  array (
    0 => 'language.oop5.references.php',
    1 => 'Objetos e Refer&ecirc;ncias',
  ),
  'next' => 
  array (
    0 => 'language.oop5.variance.php',
    1 => 'Covari&acirc;ncia e Contravari&acirc;ncia',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'pt_BR',
    'path' => 'language/oop5/serialization.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="language.oop5.serialization" class="sect1">
  <h2 class="title">Serialização de Objetos - Objetos em sessões</h2>
  

  <p class="para">
   A função <span class="function"><a href="function.serialize.php" class="function">serialize()</a></span> retorna uma string contendo uma
   representação em fluxo de bytes de qualquer valor que pode ser armazenado pelo
   PHP. A função <span class="function"><a href="function.unserialize.php" class="function">unserialize()</a></span> pode utilizar essa string para
   recriar os valores originais da variável. Utilizar a serialização para
   salvar um objeto, salvará todas as variáveis de um objeto. Os
   métodos de um objeto não são salvos, apenas o nome da
   classe.
  </p>

  <p class="para">
   Para desserializar um objeto com a função <span class="function"><a href="function.unserialize.php" class="function">unserialize()</a></span>, a
   classe desse objeto precisa estar definida. Isto é, se possuir um objeto
    da classe A e serializá-lo, você obterá
   uma string que referencia a classe A e contêm todos os valores de variáveis
   contidas nele. Se desejar desserializar este objeto
   em outro arquivo, um objeto da classe A, a
   definição da classe A deve estar presente neste arquivo.
   Isso pode ser feito, por exemplo, armazenando a definição da classe A
   em um arquivo, e incluí-lo, fazendo uso da função
   <span class="function"><a href="function.spl-autoload-register.php" class="function">spl_autoload_register()</a></span>.
  </p>

  <div class="informalexample">
   <div class="example-contents">
<div class="annotation-interactive phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #FF8000">// A.php:<br /><br />  </span><span style="color: #007700">class </span><span style="color: #0000BB">A </span><span style="color: #007700">{<br />      public </span><span style="color: #0000BB">$one </span><span style="color: #007700">= </span><span style="color: #0000BB">1</span><span style="color: #007700">;<br /><br />      public function </span><span style="color: #0000BB">show_one</span><span style="color: #007700">() {<br />          echo </span><span style="color: #0000BB">$this</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">one</span><span style="color: #007700">;<br />      }<br />  }<br /><br /></span><span style="color: #FF8000">// page1.php:<br /><br />  </span><span style="color: #007700">include </span><span style="color: #DD0000">"A.php"</span><span style="color: #007700">;<br /><br />  </span><span style="color: #0000BB">$a </span><span style="color: #007700">= new </span><span style="color: #0000BB">A</span><span style="color: #007700">;<br />  </span><span style="color: #0000BB">$s </span><span style="color: #007700">= </span><span style="color: #0000BB">serialize</span><span style="color: #007700">(</span><span style="color: #0000BB">$a</span><span style="color: #007700">);<br />  </span><span style="color: #FF8000">// armazena $s em algum lugar onde page2.php possa encontrar.<br />  </span><span style="color: #0000BB">file_put_contents</span><span style="color: #007700">(</span><span style="color: #DD0000">'caixa'</span><span style="color: #007700">, </span><span style="color: #0000BB">$s</span><span style="color: #007700">);<br /><br /></span><span style="color: #FF8000">// page2.php:<br /><br />  // isto é necessário para que a desserialização funcione adequadamente.<br />  </span><span style="color: #007700">include </span><span style="color: #DD0000">"A.php"</span><span style="color: #007700">;<br /><br />  </span><span style="color: #0000BB">$s </span><span style="color: #007700">= </span><span style="color: #0000BB">file_get_contents</span><span style="color: #007700">(</span><span style="color: #DD0000">'caixa'</span><span style="color: #007700">);<br />  </span><span style="color: #0000BB">$a </span><span style="color: #007700">= </span><span style="color: #0000BB">unserialize</span><span style="color: #007700">(</span><span style="color: #0000BB">$s</span><span style="color: #007700">);<br /><br />  </span><span style="color: #FF8000">// agora usa a função show_one() do objeto $a.<br />  </span><span style="color: #0000BB">$a</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">show_one</span><span style="color: #007700">();<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>

  <p class="para">
   É fortemente recomendado que, quando uma aplicação serializa seus objetos, para
   uso posterior na aplicação, esta inclua a definição da classe
   do objeto em questão ao longo de toda aplicação. Não fazer isso pode resultar em
   objetos serem desserializados sem a definição da classe, que acarretará no
   PHP entregar um objeto da classe <span class="classname"><strong class="classname">__PHP_Incomplete_Class_Name</strong></span>,
   que não possui métodos, tornando o objeto inútil.
  </p>

  <p class="para">
   Então, se, no exemplo anterior, <var class="varname">$a</var> se tornou parte da sessão
   adicionando uma nova chave no array superglobal <var class="varname"><a href="reserved.variables.session.php" class="classname">$_SESSION</a></var>, você deve incluir o
   arquivo <code class="literal">A.php</code> em todas suas páginas, e não somente em <var class="filename">page1.php</var>
   e <var class="filename">page2.php</var>.
  </p>

  <p class="para">
   Além dos conselhos acima, note que pode-se capturar os eventos de serialização
   e desserialização de um objeto usando os métodos
   <a href="language.oop5.magic.php#object.sleep" class="link">__sleep()</a> e
   <a href="language.oop5.magic.php#object.wakeup" class="link">__wakeup()</a>. Usar
   o método <a href="language.oop5.magic.php#object.sleep" class="link">__sleep()</a> também lhe permitirá
   serializar somente subconjuntos de propriedades de um objeto.
  </p>
 </div><?php manual_footer($setup); ?>