A partir de la versión de PHP 4.2.0 el valor por defecto de la directiva register_globals es off. El por qué de este cambio viene motivado por un aumento del nivel de seguridad en la configuración del PHP por defecto. Pero esto puede provocar que nuestras páginas dejen de funcionar.
La directiva register_globals cuando esta activada (estado que estaba por defecto antes de la versión 4.2.0 de PHP), provoca que automáticamente se generen variables globales para cookies y valores enviados por get y post entre otros.
Por ejemplo:
Si llamábamos a una página con http://www.internet.com/prueba.php?var1=4, esto provocaba que en la página prueba.php automáticamente se generase la variable $var1 con el valor 4.
Por razones de seguridad este comportamiento automático se ha cambiado, estableciendo el valor por defecto de register_globals a off.
Este cambio puede producir que nuestras antiguas páginas dejen de funcionar, ante esto tenemos dos opciones:
Debemos buscar todas aquellas variables que son definidas automáticamente, variables del servidor, que provienen de get o post, cookies, files, variables de entorno o sesión.
Reemplazar esas variables por las referencias adecuadas en cada caso, en PHP se han definido unos arrays diferentes con valores, dependiendo del lugar de procedencia. Así tenemos los arrays $_SERVER, $_GET, $_POST, $_COOKIE, $_FILES, $_ENV, $REQUEST y $_SESSION.
Si por ejemplo teníamos el siguiente script:
print "Su edad: ".$edad; //cookie print "Navegador: ".$HTTP_USER_AGENT; print "Variable: ".$var; //variable de get
Deberíamos reemplazarlas por:
print "Su edad: ".$_COOKIE['edad']; //cookie print "Navegador: ".$_SERVER['HTTP_USER_AGENT']; print "Variable: ".$_GET['var']; //variable de get
Usuarios que han visto este tema también han visto...
- Cacheando scripts para máxima optimización
- Conectarse a MySQL desde PHP
- Ocultando PHP
- rawurlencode y rawurldecode en PHP
- Introducción y Sintaxis Básica
Información legal | Política de Privacidad | Contacte con nosotros
Otro proyecto de Factoría de Internet. Copyright© 2003-2011 Factoría de Internet S.L.. Todos los derechos reservados.