<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/phar.using.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'pt_BR',
  ),
  'this' => 
  array (
    0 => 'phar.using.intro.php',
    1 => 'Usando Arquivos Phar: Introdu&ccedil;&atilde;o',
    2 => 'Usando Arquivos Phar: Introdu&ccedil;&atilde;o',
  ),
  'up' => 
  array (
    0 => 'phar.using.php',
    1 => 'Usando Arquivos Phar',
  ),
  'prev' => 
  array (
    0 => 'phar.using.php',
    1 => 'Usando Arquivos Phar',
  ),
  'next' => 
  array (
    0 => 'phar.using.stream.php',
    1 => 'Usando Arquivos Phar: o empacotador de fluxo phar',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'pt_BR',
    'path' => 'reference/phar/using.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="phar.using.intro" class="section">
 <h2 class="title">Usando Arquivos Phar: Introdução</h2>
 <p class="para">
  Os arquivos Phar são semelhantes em conceito aos arquivos JAR do Java, mas são adaptados
  às necessidades e à flexibilidade de aplicações PHP. Um arquivo Phar é
  usado para distribuir uma aplicação ou biblioteca PHP completa em um único arquivo.
  Uma aplicação de arquivo Phar é usada exatamente como qualquer outra aplicação PHP:
 </p>
 <div class="example-contents screen">
  <div class="cdata"><pre>
php aplicacaoincrivel.phar
  </pre></div>
 </div>
 <p class="para">
  Usar uma biblioteca de arquivo Phar é idêntico ao uso de qualquer outra biblioteca PHP:
 </p>
 <p class="para">
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><pre><code style="color: #000000"><span style="color: #0000BB">&lt;?php
</span><span style="color: #007700">include </span><span style="color: #DD0000">'bibliotecafantastica.phar'</span><span style="color: #007700">;
</span><span style="color: #0000BB">?&gt;</span></code></pre></div>
   </div>

  </div>
 </p>
 <p class="para">
  O empacotador de fluxo <code class="literal">phar</code> fornece o núcleo da extensão phar e
  é explicado em detalhes <a href="phar.using.stream.php" class="link">aqui</a>.
  O empacotador de fluxo phar permite acessar os arquivos dentro de um arquivo phar usando
  as funções de arquivo padrão do PHP <span class="function"><a href="function.fopen.php" class="function">fopen()</a></span>, <span class="function"><a href="function.opendir.php" class="function">opendir()</a></span> e
  outras que funcionam em arquivos comuns. O empacotador de fluxo <code class="literal">phar</code> suporta todas as
  operações de leitura/gravação em arquivos e diretórios.
 </p>
 <p class="para">
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><pre><code style="color: #000000"><span style="color: #0000BB">&lt;?php
</span><span style="color: #007700">include </span><span style="color: #DD0000">'phar://bibliotecafantastica.phar/interno/arquivo.php'</span><span style="color: #007700">;
</span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">'Content-type: image/jpeg'</span><span style="color: #007700">);
</span><span style="color: #FF8000">// phars pode ser acessado pelo caminho completo ou por apelido
</span><span style="color: #007700">echo </span><span style="color: #0000BB">file_get_contents</span><span style="color: #007700">(</span><span style="color: #DD0000">'phar:///caminhocompleto/para/bibliotecafantastica.phar/imagens/uau.jpg'</span><span style="color: #007700">);
</span><span style="color: #0000BB">?&gt;</span></code></pre></div>
   </div>

  </div>
 </p>
 <p class="para">
  A classe <span class="classname"><a href="class.phar.php" class="classname">Phar</a></span> implementa funcionalidades avançadas para acessar
  arquivos e criar arquivos phar. A classe Phar é explicada em detalhes
  <a href="phar.using.object.php" class="link">aqui</a>.
 </p>
 <p class="para">
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><pre><code style="color: #000000"><span style="color: #0000BB">&lt;?php
</span><span style="color: #007700">try {
    </span><span style="color: #FF8000">// abre um phar existente
    </span><span style="color: #0000BB">$p </span><span style="color: #007700">= new </span><span style="color: #0000BB">Phar</span><span style="color: #007700">(</span><span style="color: #DD0000">'bibliotecafantastica.phar'</span><span style="color: #007700">, </span><span style="color: #0000BB">0</span><span style="color: #007700">);
    </span><span style="color: #FF8000">// Phar estende a classe DirectoryIterator do SPL
    </span><span style="color: #007700">foreach (new </span><span style="color: #0000BB">RecursiveIteratorIterator</span><span style="color: #007700">(</span><span style="color: #0000BB">$p</span><span style="color: #007700">) as </span><span style="color: #0000BB">$file</span><span style="color: #007700">) {
        </span><span style="color: #FF8000">// $file é uma classe PharFileInfo e herda de SplFileInfo
        </span><span style="color: #007700">echo </span><span style="color: #0000BB">$file</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getFileName</span><span style="color: #007700">() . </span><span style="color: #DD0000">"\n"</span><span style="color: #007700">;
        echo </span><span style="color: #0000BB">file_get_contents</span><span style="color: #007700">(</span><span style="color: #0000BB">$file</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getPathName</span><span style="color: #007700">()) . </span><span style="color: #DD0000">"\n"</span><span style="color: #007700">; </span><span style="color: #FF8000">// exibir conteúdo;
    </span><span style="color: #007700">}
    if (isset(</span><span style="color: #0000BB">$p</span><span style="color: #007700">[</span><span style="color: #DD0000">'internal/file.php'</span><span style="color: #007700">])) {
        </span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$p</span><span style="color: #007700">[</span><span style="color: #DD0000">'internal/file.php'</span><span style="color: #007700">]-&gt;</span><span style="color: #0000BB">getMetadata</span><span style="color: #007700">());
    }

    </span><span style="color: #FF8000">// cria um novo phar - phar.readonly deve ser 0 em php.ini
    // phar.readonly é habilitado por padrão por motivos de segurança.
    // Em servidores de produção, Phars nunca precisam ser criados,
    // apenas executados.
    </span><span style="color: #007700">if (</span><span style="color: #0000BB">Phar</span><span style="color: #007700">::</span><span style="color: #0000BB">canWrite</span><span style="color: #007700">()) {
        </span><span style="color: #0000BB">$p </span><span style="color: #007700">= new </span><span style="color: #0000BB">Phar</span><span style="color: #007700">(</span><span style="color: #DD0000">'novophar.tar.phar'</span><span style="color: #007700">, </span><span style="color: #0000BB">0</span><span style="color: #007700">, </span><span style="color: #DD0000">'novophar.tar.phar'</span><span style="color: #007700">);
        </span><span style="color: #FF8000">// faz deste um arquivo phar baseado em tar, compactado com compressão gzip (.tar.gz)
        </span><span style="color: #0000BB">$p </span><span style="color: #007700">= </span><span style="color: #0000BB">$p</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">convertToExecutable</span><span style="color: #007700">(</span><span style="color: #0000BB">Phar</span><span style="color: #007700">::</span><span style="color: #0000BB">TAR</span><span style="color: #007700">, </span><span style="color: #0000BB">Phar</span><span style="color: #007700">::</span><span style="color: #0000BB">GZ</span><span style="color: #007700">);

        </span><span style="color: #FF8000">// cria transação - nada é escrito em novophar.phar
        // até que stopBuffering() seja chamado, embora seja necessário armazenamento temporário
        </span><span style="color: #0000BB">$p</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">startBuffering</span><span style="color: #007700">();
        </span><span style="color: #FF8000">// adiciona todos os arquivos em /caminho/para/projeto, salvando no phar com o prefixo "projeto"
        </span><span style="color: #0000BB">$p</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">buildFromIterator</span><span style="color: #007700">(new </span><span style="color: #0000BB">RecursiveIteratorIterator</span><span style="color: #007700">(new </span><span style="color: #0000BB">RecursiveDirectoryIterator</span><span style="color: #007700">(</span><span style="color: #DD0000">'/caminho/para/projeto'</span><span style="color: #007700">)), </span><span style="color: #DD0000">'/caminho/para/'</span><span style="color: #007700">);

        </span><span style="color: #FF8000">// adiciona um novo arquivo por meio da API de acesso a array
        </span><span style="color: #0000BB">$p</span><span style="color: #007700">[</span><span style="color: #DD0000">'arquivo1.txt'</span><span style="color: #007700">] = </span><span style="color: #DD0000">'Informação'</span><span style="color: #007700">;
        </span><span style="color: #0000BB">$fp </span><span style="color: #007700">= </span><span style="color: #0000BB">fopen</span><span style="color: #007700">(</span><span style="color: #DD0000">'arquivogigante.dat'</span><span style="color: #007700">, </span><span style="color: #DD0000">'rb'</span><span style="color: #007700">);
        </span><span style="color: #FF8000">// copia todos os dados do fluxo
        </span><span style="color: #0000BB">$p</span><span style="color: #007700">[</span><span style="color: #DD0000">'dados/arquivogigante.dat'</span><span style="color: #007700">] = </span><span style="color: #0000BB">$fp</span><span style="color: #007700">;

        if (</span><span style="color: #0000BB">Phar</span><span style="color: #007700">::</span><span style="color: #0000BB">canCompress</span><span style="color: #007700">(</span><span style="color: #0000BB">Phar</span><span style="color: #007700">::</span><span style="color: #0000BB">GZ</span><span style="color: #007700">)) {
            </span><span style="color: #0000BB">$p</span><span style="color: #007700">[</span><span style="color: #DD0000">'dados/arquivogigante.dat'</span><span style="color: #007700">]-&gt;</span><span style="color: #0000BB">compress</span><span style="color: #007700">(</span><span style="color: #0000BB">Phar</span><span style="color: #007700">::</span><span style="color: #0000BB">GZ</span><span style="color: #007700">);
        }

        </span><span style="color: #0000BB">$p</span><span style="color: #007700">[</span><span style="color: #DD0000">'imagens/uau.jpg'</span><span style="color: #007700">] = </span><span style="color: #0000BB">file_get_contents</span><span style="color: #007700">(</span><span style="color: #DD0000">'imagens/uau.jpg'</span><span style="color: #007700">);
        </span><span style="color: #FF8000">// qualquer valor pode ser salvo como metadados específicos do arquivo
        </span><span style="color: #0000BB">$p</span><span style="color: #007700">[</span><span style="color: #DD0000">'imagens/uau.jpg'</span><span style="color: #007700">]-&gt;</span><span style="color: #0000BB">setMetadata</span><span style="color: #007700">(array(</span><span style="color: #DD0000">'mime-type' </span><span style="color: #007700">=&gt; </span><span style="color: #DD0000">'image/jpeg'</span><span style="color: #007700">));
        </span><span style="color: #0000BB">$p</span><span style="color: #007700">[</span><span style="color: #DD0000">'index.php'</span><span style="color: #007700">] = </span><span style="color: #0000BB">file_get_contents</span><span style="color: #007700">(</span><span style="color: #DD0000">'index.php'</span><span style="color: #007700">);
        </span><span style="color: #0000BB">$p</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">setMetadata</span><span style="color: #007700">(array(</span><span style="color: #DD0000">'bootstrap' </span><span style="color: #007700">=&gt; </span><span style="color: #DD0000">'index.php'</span><span style="color: #007700">));

        </span><span style="color: #FF8000">// salva o arquivo phar no disco
        </span><span style="color: #0000BB">$p</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">stopBuffering</span><span style="color: #007700">();
    }
} catch (</span><span style="color: #0000BB">Exception $e</span><span style="color: #007700">) {
    echo </span><span style="color: #DD0000">'Não foi possível abrir o Phar: '</span><span style="color: #007700">, </span><span style="color: #0000BB">$e</span><span style="color: #007700">;
}
</span><span style="color: #0000BB">?&gt;</span></code></pre></div>
   </div>

  </div>
 </p>
 <p class="para">
  Além disso, a verificação do conteúdo do arquivo phar pode ser feita usando qualquer um dos
  algoritmos de hash simétricos suportados (MD5, SHA1, SHA256 e SHA512 se ext/hash estiver habilitado)
  e usando assinatura assimétrica de chave pública/privada usando OpenSSL. Para
  aproveitar a assinatura OpenSSL, é necessário gerar um par de chaves pública/privada e
  usar a chave privada para definir a assinatura usando
  <span class="function"><a href="phar.setsignaturealgorithm.php" class="function">Phar::setSignatureAlgorithm()</a></span>. Adicionalmente, a chave pública
  extraída usando este código:
  <div class="example-contents">
   <div class="phpcode"><pre><code style="color: #000000"><span style="color: #0000BB">&lt;?php
$public </span><span style="color: #007700">= </span><span style="color: #0000BB">openssl_get_publickey</span><span style="color: #007700">(</span><span style="color: #0000BB">file_get_contents</span><span style="color: #007700">(</span><span style="color: #DD0000">'private.pem'</span><span style="color: #007700">));
</span><span style="color: #0000BB">$pkey </span><span style="color: #007700">= </span><span style="color: #DD0000">''</span><span style="color: #007700">;
</span><span style="color: #0000BB">openssl_pkey_export</span><span style="color: #007700">(</span><span style="color: #0000BB">$public</span><span style="color: #007700">, </span><span style="color: #0000BB">$pkey</span><span style="color: #007700">);
</span><span style="color: #0000BB">?&gt;</span></code></pre></div>
  </div>

  deve ser salva adjacente ao arquivo phar que ela verifica. Se o arquivo phar
  for salvo como <code class="literal">/caminho/para/meu.phar</code>, a chave pública deve ser salva
  como <code class="literal">/caminho/para/meu.phar.pubkey</code>, ou o phar não conseguirá verificar
  a assinatura OpenSSL.
 </p>
 <p class="para">
  A classe <span class="classname"><a href="class.phar.php" class="classname">Phar</a></span> também fornece 3 métodos estáticos, <span class="function"><a href="phar.webphar.php" class="function">Phar::webPhar()</a></span>,
  <span class="function"><a href="phar.mungserver.php" class="function">Phar::mungServer()</a></span> e <span class="function"><a href="phar.interceptfilefuncs.php" class="function">Phar::interceptFileFuncs()</a></span>, que são cruciais
  para empacotar aplicações PHP projetadas para uso em sistemas de arquivos comuns e para aplicações web.
  <span class="function"><a href="phar.webphar.php" class="function">Phar::webPhar()</a></span> implementa um controlador de frente que roteia chamadas HTTP para o local correto
  dentro do arquivo phar. <span class="function"><a href="phar.mungserver.php" class="function">Phar::mungServer()</a></span> é usado para modificar os valores
  do array <var class="varname"><a href="reserved.variables.server.php" class="classname">$_SERVER</a></var> para enganar aplicações que processam esses valores.
  <span class="function"><a href="phar.interceptfilefuncs.php" class="function">Phar::interceptFileFuncs()</a></span> instrui o Phar a interceptar chamadas para
  <span class="function"><a href="function.fopen.php" class="function">fopen()</a></span>, <span class="function"><a href="function.file-get-contents.php" class="function">file_get_contents()</a></span>, <span class="function"><a href="function.opendir.php" class="function">opendir()</a></span> e
  todas as funções baseadas em estatísticas (<span class="function"><a href="function.file-exists.php" class="function">file_exists()</a></span>, <span class="function"><a href="function.is-readable.php" class="function">is_readable()</a></span> e assim por diante) e
  rotear todos os caminhos relativos para locais dentro do arquivo phar.
 </p>
 <p class="para">
  Por exemplo, empacotar uma versão do popular aplicativo phpMyAdmin para uso como um arquivo phar requer
  apenas este script simples e então <code class="literal">phpMyAdmin.phar.tar.php</code> pode ser acessado como um arquivo normal
  a partir do servidor web após modificar o usuário/senha:
 </p>
 <p class="para">
  <div class="informalexample">
   <div class="example-contents">
    <div class="phpcode"><pre><code style="color: #000000"><span style="color: #0000BB">&lt;?php
</span><span style="color: #007700">@</span><span style="color: #0000BB">unlink</span><span style="color: #007700">(</span><span style="color: #DD0000">'phpMyAdmin.phar.tar.php'</span><span style="color: #007700">);
</span><span style="color: #0000BB">copy</span><span style="color: #007700">(</span><span style="color: #DD0000">'phpMyAdmin-2.11.3-english.tar.gz'</span><span style="color: #007700">, </span><span style="color: #DD0000">'phpMyAdmin.phar.tar.php'</span><span style="color: #007700">);
</span><span style="color: #0000BB">$a </span><span style="color: #007700">= new </span><span style="color: #0000BB">Phar</span><span style="color: #007700">(</span><span style="color: #DD0000">'phpMyAdmin.phar.tar.php'</span><span style="color: #007700">);
</span><span style="color: #0000BB">$a</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">startBuffering</span><span style="color: #007700">();
</span><span style="color: #0000BB">$a</span><span style="color: #007700">[</span><span style="color: #DD0000">"phpMyAdmin-2.11.3-english/config.inc.php"</span><span style="color: #007700">] = </span><span style="color: #DD0000">'&lt;?php
/* Configuração de servidores */
$i = 0;

/* Servidor localhost (config:root) [1] */
$i++;
$cfg[\'Servers\'][$i][\'host\'] = \'localhost\';
$cfg[\'Servers\'][$i][\'extension\'] = \'mysqli\';
$cfg[\'Servers\'][$i][\'connect_type\'] = \'tcp\';
$cfg[\'Servers\'][$i][\'compress\'] = false;
$cfg[\'Servers\'][$i][\'auth_type\'] = \'config\';
$cfg[\'Servers\'][$i][\'user\'] = \'root\';
$cfg[\'Servers\'][$i][\'password\'] = \'\';


/* Fim da configuração dos servidores */
if (strpos(PHP_OS, \'WIN\') !== false) {
    $cfg[\'UploadDir\'] = getcwd();
} else {
    $cfg[\'UploadDir\'] = \'/tmp/pharphpmyadmin\';
    @mkdir(\'/tmp/pharphpmyadmin\');
    @chmod(\'/tmp/pharphpmyadmin\', 0777);
}'</span><span style="color: #007700">;
</span><span style="color: #0000BB">$a</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">setStub</span><span style="color: #007700">(</span><span style="color: #DD0000">'&lt;?php
Phar::interceptFileFuncs();
Phar::webPhar("phpMyAdmin.phar", "phpMyAdmin-2.11.3-english/index.php");
echo "O phpMyAdmin foi projetado para ser executado a partir de um navegador da web\n";
exit -1;
__HALT_COMPILER();
'</span><span style="color: #007700">);
</span><span style="color: #0000BB">$a</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">stopBuffering</span><span style="color: #007700">();
</span><span style="color: #0000BB">?&gt;</span></code></pre></div>
   </div>

  </div>
 </p>
</div><?php manual_footer($setup); ?>