<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/security.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'es',
  ),
  'this' => 
  array (
    0 => 'security.hiding.php',
    1 => 'Ocultar PHP',
    2 => 'Ocultar PHP',
  ),
  'up' => 
  array (
    0 => 'security.php',
    1 => 'Seguridad',
  ),
  'prev' => 
  array (
    0 => 'security.variables.php',
    1 => 'Datos Enviados por el Usuario',
  ),
  'next' => 
  array (
    0 => 'security.current.php',
    1 => 'Mantenerse al d&iacute;a',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'es',
    'path' => 'security/hiding.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="security.hiding" class="chapter">
 <h1 class="title">Ocultar PHP</h1>

 <p class="para">
  En general, la seguridad por ocultación es una de las formas más débiles de seguridad.
  Aunque en algunos casos, es aconsejable cada pequeño elemento extra de seguridad.
 </p>
 <p class="para">
  Unas cuantas técnicas simples pueden ayudar a ocultar <abbr title="PHP: Hypertext Preprocessor">PHP</abbr>, posiblemente retrasando
  a un atacante que esté tratando de descubrir debilidades en el
  sistema. Al establecer expose_php a <code class="literal">off</code> en el
  fichero <var class="filename">php.ini</var>, se reduce la cantidad de información disponible.
 </p>
 <p class="para">
  Otra táctica es configurar servidores web como Apache para
  interpretar diferentes tipos de ficheros por medio de <abbr title="PHP: Hypertext Preprocessor">PHP</abbr>, ya sea con una directiva
  de <var class="filename">.htaccess</var> o en el propio fichero de configuración de Apache. Así se pueden
  utilizar extensiones de ficheros engañosas:
  <div class="example" id="example-1">
   <p><strong>Ejemplo #1 Ocultando PHP como si fuera otro lenguaje</strong></p>
   <div class="example-contents">
<div class="apache-confcode"><pre class="apache-confcode"># Hacer que el código de PHP parezca otro tipo de código
AddType application/x-httpd-php .asp .py .pl</pre>
</div>
   </div>

  </div>
  U ocultarlo completamente:
  <div class="example" id="example-2">
   <p><strong>Ejemplo #2 Utilizar tipos desconocidos para extensiones de PHP</strong></p>
   <div class="example-contents">
<div class="apache-confcode"><pre class="apache-confcode"># Hacer que el código de PHP parezca de tipo desconocido
AddType application/x-httpd-php .bop .foo .133t</pre>
</div>
   </div>

  </div>
  U ocultarlo como código <abbr title="Hyper Text Markup Language">HTML</abbr>, lo cual tiene un pequeño impacto de rendimiento debido
  a que todos los ficheros <abbr title="Hyper Text Markup Language">HTML</abbr> serán procesados por el motor de <abbr title="PHP: Hypertext Preprocessor">PHP</abbr>:
  <div class="example" id="example-3">
   <p><strong>Ejemplo #3 Utilizar tipos <abbr title="Hyper Text Markup Language">HTML</abbr> para extensiones de PHP</strong></p>
   <div class="example-contents">
<div class="apache-confcode"><pre class="apache-confcode"># Hacer que el código de PHP parezca HTML
AddType application/x-httpd-php .htm .html</pre>
</div>
   </div>

  </div>
  Para que esto funcione eficazmente, se debe cambiar el nombre de los ficheros <abbr title="PHP: Hypertext Preprocessor">PHP</abbr> con
  las extensiones de arriba. Si bien es una forma de seguridad por
  ocultamiento, es una medida preventiva menor con pocos inconvenientes.
 </p>
</div>
<?php manual_footer($setup); ?>