You are on page 1of 32

Manual de PHP

MANUAL DE PHP
Primeros Pasos
Conceptos Bsicos
El lenguaje PHP cuyo nombre es el acrnimo recursivo de "PHP: Hypertext Preprocessor" (inicialmente PHP Tools, o, Personal Home Page Tools) es un lenguaje de programacin de estilo clsico, con esto quiero decir que es un lenguaje de programacin con variables, sentencias condicionales, bucles, funciones.... No es un lenguaje de marcas como podra ser HTML, XML o WML. Est ms cercano a JavaScript o a C, para aquellos que conocen estos lenguajes. Pero a diferencia de Java o JavaScript que se ejecutan en el navegador, PHP se ejecuta en el servidor, por eso nos permite acceder a los recursos que tenga el servidor como por ejemplo podra ser una base de datos. El programa PHP es ejecutado en el servidor y el resultado enviado al navegador. El resultado es normalmente una pgina HTML pero igualmente podra ser una pgina WML.

Al ser PHP un lenguaje que se ejecuta en el servidor no es necesario que su navegador lo soporte, es independiente del navegador, pero sin embargo para que sus pginas PHP funcionen, el servidor donde estn alojadas debe soportar PHP.

Nuestro Primer PHP


La ventaja que tiene PHP sobre otros lenguajes de programacin que se ejecutan en el servidor (como podran ser los script CGI Perl), es que nos permite intercalar las sentencias PHP en las paginas HTML, es un concepto algo complicado de entender si no se ha visto nunca como funciona unas pginas PHP o ASP. Vamos a ver un ejemplo sencillo para comprenderlo mejor. ejemplophp.php <html> <head> <title>Ejemplo 1 de PHP</title> </head> <body> Parte de HTML normal. <br><br> <?php echo "Parte de PHP<br>"; for($i=0;$i<10;$i++) { echo "Linea ".$i."<br>"; } ?> </body> </html> El cdigo PHP ejecutado tiene dos partes: la primera imprime "Parte de PHP" y la segunda es un bucle que se ejecuta 10 veces de 0 a 9, por cada vez que se ejecuta se escribe una lnea, la variable $i contiene el nmero de lnea que se est escribiendo. No importa si no entiende muy bien el programa este ejemplo solo es para ilustrar como se intercala el cdigo HTML y el cdigo PHP.

Variables
Una variable es un contenedor de informacin, en el que podemos meter nmeros enteros, nmeros decimales, caracteres... el contenido de las variables se puede leer y se puede cambiar durante la ejecucin de una pgina PHP.

Manual de PHP

En PHP todas las variables comienzan con el smbolo del dlar $ y no es necesario definir una variable antes de usarla. Tampoco tienen tipos, es decir que una misma variable puede contener un nmero y luego puede contener caracteres. holamundo.php <html> <head> <title>Ejemplo de PHP</title> </head> <body> <?php $a = 1; $b = 3.34; $c = "Hola Mundo"; echo $a,"<br>",$b,"<br>",$c; ?> </body> </html> En este ejemplo hemos definido tres variables, $a, $b y $c y con la instruccin echo hemos impreso el valor que contenan, insertando un salto de lnea entre ellas. Existen 2 tipos de variables, las variables locales que solo pueden ser usadas dentro de funciones y las variables globales que tienen su mbito de uso fuera de las funciones, podemos acceder a una variable global desde una funcin con la instruccin global nombre_variable;

Operadores Aritmticos
Los operadores de PHP son muy parecidos a los de C y JavaScript, si usted conoce estos lenguajes le resultaran familiares y fciles de reconocer. Estos son los operadores que se pueden aplicar a las variables y constantes numricas. Operador Nombre + * / % ++ -Suma Resta Multiplicacin Divisin Mdulo Suma 1 Resta 1 Ejemplo Descripcin 5+6 7-9 6*3 4/8 7%2 $a++ $a-Suma dos nmeros Resta dos nmeros Multiplica dos nmeros Divide dos nmeros Devuelve el resto de dividir ambos nmeros, en este ejemplo el resultado es 1 Suma 1 al contenido de una variable. Resta 1 al contenido de una variable.

operaritmeticos.php <html> <head> <title>Operadores aritmticos</title> </head> <body> <?php $a = 8; $b = 3; echo $a + $b,"<br>"; echo $a - $b,"<br>"; echo $a * $b,"<br>"; echo $a / $b,"<br>"; $a++; echo $a,"<br>"; $b--; echo $b,"<br>"; ?> </body> </html>

Manual de PHP Operadores de Comparacin


Los operadores de comparacin son usados para comparar valores y as poder tomar decisiones. Operador Nombre == != < > <= >= operacomparacion.php <html> <head> <title>Operadores de comparacin</title> </head> <body> <?php $a = 8; $b = 3; $c = 3; echo $a == $b,"<br>"; echo $a != $b,"<br>"; echo $a < $b,"<br>"; echo $a > $b,"<br>"; echo $a >= $c,"<br>"; echo $b <= $c,"<br>"; ?> </body> </html> Igual Distinto Menor que Mayor que Ejemplo Devuelve cierto cuando: $a == $b $a es igual $b $a != $b $a es distinto $b $a < $b $a > $b $a es menor que $b $a es mayor que $b

Menor o igual $a <= $b $a es menor o igual que $b Mayor o igual $a >= $b $a es mayor o igual que $b

Operadores Lgicos
Los operadores lgicos son usados para evaluar varias comparaciones, combinando los posibles valores de estas. Operador Nombre && and || or ! Y Y O O No Ejemplo Devuelve cierto cuando:

(7>2) && (2<4) Devuelve verdadero cuando ambas condiciones son verdaderas. (7>2) and (2<4) Devuelve verdadero cuando ambas condiciones son verdaderas. (7>2) || (2<4) (7>2) or (2<4) ! (7>2) Devuelve verdadero cuando al menos una de las dos es verdadera. Devuelve verdadero cuando al menos una de las dos es verdadera. Niega el valor de la expresin.

operalogicos.php <html> <head> <title>Operadores lgicos</title> </head> <body> <?php $a = 8; $b = 3; $c = 3; echo ($a == $b) && ($c > $b),"<br>"; echo ($a == $b) || ($b == $c),"<br>"; echo !($b <= $c),"<br>"; ?> </body> </html>

Manual de PHP Sentencias de Control


Condicionales If

Las sentencias condicionales nos permiten ejecutar o no unas ciertas instrucciones dependiendo del resultado de evaluar una condicin. Las ms frecuentes son la instruccin if y la instruccin switch. <?php if (condicin) { Sentencias a ejecutar cuando la condicin es cierta. } else { Sentencias a ejecutar cuando la condicin es falsa. } ?> La sentencia if ejecuta una serie de instrucciones u otras dependiendo de la condicin que le pongamos. Probablemente sea la instruccin ms importante en cualquier lenguaje de programacin. if.php <html> <head><title>Sentencia If</title> </head> <body> <?php $a = 8; $b = 3; if ($a < $b) { echo "a es menor que b"; } else { echo "a no es menor que b"; } ?> </body> </html> En este ejemplo la condicin no es verdadera por lo que se ejecuta la parte de cdigo correspondiente al else.

Switch
Con la sentencia switch podemos ejecutar unas u otras instrucciones dependiendo del valor de una variable, en el ejemplo anterior, dependiendo del valor de la variable $posicion se ejecuta el bloque 1 cuando el valor es "arriba", el bloque 2 cuando el valor es "abajo" y el bloque 3 si no es ninguno de los valores anteriores. switch.php <html> <head> <title> Switch</title> </head> <body> <?php $posicion = "arriba"; switch($posicion) { case "arriba": // Bloque 1 echo "La variable contiene"; echo " el valor arriba"; break; case "abajo": // Bloque 2 echo "La variable contiene"; echo " el valor abajo"; break; default: // Bloque 3

Manual de PHP
echo "La variable contiene otro valor"; echo " distinto de arriba y abajo"; } ?> </body> </html>

Bucles
Los bucles nos permiten iterar conjuntos de instrucciones, es decir repetir la ejecucin de un conjunto de instrucciones mientras se cumpla una condicin. <?php while (condicin) { Instrucciones a ejecutar. } ?> Mientras la condicin sea cierta se reiterar la ejecucin de las instrucciones que estn dentro del while.

Ciclo While
En el siguiente ejemplo, el valor de $i al comienzo es 0, durante la ejecucin del bucle, se va sumando 1 al valor de $i de manera que cuando $i vale 10 ya no se cumple la condicin y se termina la ejecucin del bucle. ciclowhile.php <html> <head> <title>Ciclo While</title> </head> <body> Inicio<BR> <?php $i=0; while ($i<10) { echo "El valor de i es ", $i,"<br>"; $i++; } ?> Final<BR> </body> </html>

Ciclo For
La instruccin for es la instruccin de bucles ms completa. En una sola instruccin nos permite controlar todo el funcionamiento del bucle. <?php for (inicial ; condicin ; ejecutar en iteracin) { instrucciones a ejecutar. } ?> ciclofor.php <html> <head> <title>Ciclo For</title> </head> <body> Inicio<BR> <?php for($i=0 ; $i<10 ; $i++)

Manual de PHP
{ echo "El valor de i es ", $i,"<br />"; } ?> Final<br /> </body> </html>

El primer parmetro del for, es ejecutado la primera vez y sirve para inicializar la variable del bucle, el segundo parmetro indica la condicin que se debe cumplir para que el bucle siga ejecutndose y el tercer parmetro es una instruccin que se ejecuta al final de cada iteracin y sirve para modificar el valor de la variable de iteracin.

Instrucciones de Salida
Hasta ahora hemos usado la instruccin echo para realizar salida a pantalla, esta instruccin es limitada ya que no permite formatear la salida. En esta pgina veremos la instruccin printf que es ms potente.

Sentencia printf
<?php printf(cadena formato, variable1, variable2...); ?> La cadena de formateo indica cmo se han de representar las valores que posteriormente le indicaremos. La principal ventaja es que adems de poder formatear los valores de salida, nos permite intercalar texto entre ellos. sentenciaprintf.php <html> <head> <title>Printf</title> </head> <body> <?php printf("El numero dos con diferentes formatos: %d %f %.2f",2,2,2); ?> </body> </html> La cadena de formato puede incluir una seria de caracteres especiales que indican como formatear las variables que se incluyen en la instruccin. Elemento Tipo de variable %s %d %f %c Cadena de caracteres. Nmero sin decimales. Nmero con decimales. Carcter ASCII.

Aunque existen otros tipos, estos son los ms importantes. sentenciaprintf1.php <html> <head> <title>Sentencia printf</title> </head> <body> <?php $var="texto"; $num=3; printf("Puede fcilmente intercalar <b>%s</b> con nmeros <b>%d</b> <br />", $var, $num); echo("<table border=1 cellpadding=20>"); for ($i=0;$i<10;$i++) { printf("<tr><td>%10.d</td></tr>",$i); }

Manual de PHP
printf("</table>"); ?> </body> </html>

Manejo de Cadenas
Dado el uso del lenguaje PHP el tratamiento de cadenas es muy importante, existen bastantes funciones para el manejo de cadenas, a continuacin explicaremos las ms usadas. strlen(cadena). Nos devuelve el nmero de caracteres de una cadena. split(separador,cadena). Divide una cadena en varias usando un carcter separador. sprintf(cadena de formato, var1, var2...). Formatea una cadena de texto al igual que printf pero el resultado es devuelto como una cadena. substr(cadena, inicio, longitud). Devuelve una subcadena de otra, empezando por inicio y de longitud longitud. chop(cadena). Elimina los saltos de lnea y los espacios finales de una cadena. strpos(cadena1, cadena2). Busca la cadena2 dentro de cadena1 indicndonos la posicin en la que se encuentra. str_replace(cadena1, cadena2, texto). Reemplaza la cadena1 por la cadena2 en el texto. manejodecadenas.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Manejo de cadenas</title> </head> <body> <?php echo strlen("12345"),"<br>"; $palabras=split(" ","Esto es una prueba"); for($i=0;$palabras[$i];$i++) echo $palabras[$i],"<br>"; $resultado=sprintf("8x5 = %d <br>",8*5); echo $resultado,"<br>"; echo substr("Devuelve una subcadena de otra",9,3),"<br><br>"; if (chop("Cadena \n\n ") == "Cadena") echo "Iguales<br><br>"; echo strpos("Busca la palabra dentro de la frase", "palabra"),"<br><br>"; echo str_replace("verde","rojo","Un pez de color verde, como verde es la hierba."),"<br>"; ?> </body> </html>

Funciones
El uso de funciones nos da la capacidad de agrupar varias instrucciones bajo un solo nombre y poder llamarlas a estas varias veces desde diferentes sitios, ahorrndonos la necesidad de escribirlas de nuevo. <?php function Nombre(parametro1, parametro2...) { instruccin1; instruccin2; //varias instrucciones return valor_de_retorno; } ?> Opcionalmente podemos pasarle parmetros a las funciones que se trataran como variable locales y as mismo podemos devolver un resultado con la instruccin return valor; Esto produce la terminacin de la funcin retornando un valor. funcionmedia.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Funcin Media Aritmtica</title> </head> <body> <?php function media_aritmetica($a, $b)

Manual de PHP
{ $media=($a+$b)/2; return $media; } echo "La Media aritmtica de 4 y 6 es: ", media_aritmetica(4,6),"<br>"; echo "La Media aritmtica de 3242 y 524543 es: ", media_aritmetica(3242,524543),"<br>"; ?> </body> </html>

Las funciones ayudan a automatizar tareas y contribuyen a que tu cdigo sea ms entendible para ti y para otros que deban trabajar con l. Esto mismo sugiere que los nombres de las funciones deben ser apropiados y descriptivos. Por ejemplo, el siguiente cdigo es bastante entendible por cualquiera: <?php $monto = 100500; $meses = 24; $interes = interesaplazo($monto, $meses); $descuento = descuentoporvolumen($monto); $total = $monto + $interes - $descuento ?> Aqu no importa qu mtodo se usa para calcular el inters, simplemente se aplica. Tambin, la tasa de inters puede ir dentro de la funcin; los tramos de descuento se evalan dentro de la funcin; si se ingresan datos extraos (letras en vez de nmeros) stos se verifican dentro de la funcin. En fin, las funciones ayudan a mantener un orden que se agradece mucho cuando intentas detectar algn error. Tambin ayudan al trabajo en equipo.

Libreras
El uso de libreras es tremendamente til, nos permiten agrupar varias funciones y variables en un mismo fichero, de manera que luego podemos incluir esta librera en distintas pginas y disponer de esas funciones fcilmente. <?php function cabeceraPagina() { ?> <h1> Esta cabecera estar en todas sus pginas.</h1><br><hr> <? } function piePagina() {?> <hr> <h1>Este es el pie de pgina.</h1><br> Autor: Softedem <? } ?> Ahora vamos a crear 2 pginas que usan la librera definida anteriormente para conseguir que las dos pginas tengan la misma cabecera y pie de pgina. La instruccin para incluir una librera en nuestra pgina es include(nombre de librera) include.php <html> <head> <title>Ejemplo de PHP</title> </head> <body> <?php include("libreria01.php"); ?> <?php cabeceraPagina(); ?> Pgina 1 <br> Contenido de la pgina que estoy creando<br /> ms cosas...<br /> <?php piePagina(); ?> </body> </html>

Manual de PHP
include1.php <html> <head> <title>Ejemplo de PHP</title> </head> <body> <?php include("libreria01.php") ?> <?php cabeceraPagina(); ?> Esta es otra pgina<br><br> completamente distinta<br><br> pero comparte el pie y la cabecera con la otra.<br><br> <?php piePagina(); ?> </body> </html>

Fecha y Hora
En esta leccin vamos a ver como algunas funciones relacionadas con el tiempo y la fecha, as como algunos ejemplos prcticos.

time
Devuelve el nmero de segundos transcurridos desde el 1 de Enero de 1970. A esta forma de expresar fecha y hora se le denomina timestamp.

date(formato, timestamp)
La funcin date devuelve una cadena formateada segn los cdigo de formato. Si no le pasamos la variable timestamp nos devuelve la cadena formateada para la fecha y la hora actual. Los cdigos de formato para la funcin date son: CDIGO DESCRIPCIN

a A d D F h H i j l m M s y Y z

am o pm AM o PM Da del mes con ceros Abreviatura del da de la semana (ingls) Nombre del mes (ingls) Hora en formato 1-12 Hora en formato 0-23 Minutos Da del mes sin ceros Da de la semana Nmero de mes (1-12) Abreviatura del mes (ingls) Segundos Ao con 2 dgitos Ao con 4 dgitos Dia del ao (1-365)

Para ver algunos ejemplos supongamos que ahora es el 7 de abril de 2000 Para ver algunos ejemplos supongamos que ahora es el 7 de abril de 2000 a las 14 horas 30 minutos y 22 segundos: date("d-m-Y") -> 07-04-2007 date("H:i:s") -> 14:30:22 date("Y") -> 2007 date("YmdHis") -> 20070407143022 date("d/m/y H:i a") -> 07/04/07 14:30 pm date(d-m-Y H:i, time()) -> el momento actual mktime(hora, min, seg, mes, da, ao) La funcin mktime devuelve una variable de tipo timestamp a partir de las coordenadas dadas. La principal utilidad de esta funcin es la de aadir o quitar una determinada cantidad de fecha u horas a una dada. date.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

Manual de PHP
<title>Manejo de Fechas</title> </head> <body> <?php function restarDias($numdias, $date) { if (isset($date)) { $date = time(); } list($hora, $min, $seg, $dia, $mes, $anno) = explode( " ", date( "H i s d m Y")); $d = $dia - $numdias; $fecha = date("d-m-Y", mktime($hora, $min, $seg, $mes, $d, $anno)); return $fecha; } echo "Fecha actual: ". date( "d-m-Y")."<br />"; echo "Resta 5 das a la fecha actual: ". restarDias(5,$date)."<br />"; echo "Resta 10 das a la fecha actual: ". restarDias(10,$date)."<br />"; ?> Ejercicio: Realice este ejercicio ingresando, mediante una caja de texto, los das a descontar. </body> </html>

10

chekdate (mes, da, ao)


La funcin chekdate comprueba si una fecha es vlida, si es as devuelve TRUE y si no lo es FALSE. Una fecha se considera vlida si el ao est entre 1900 y 32767, el mes entre 1 y 12, y el da es menor o igual que nmero de das total del mes en cuestin. chekdate.php <?php if (checkdate(9,29,2009)) { echo "La fecha es correcta"; } else { echo "La fecha es incorrecta"; } ?> Para el ejemplo anterior nos dara que la fecha es incorrecta, febrero nunca tiene un da 31.

Envo y Recepcin de Datos


El lenguaje PHP nos proporciona una manera sencilla de manejar formularios, permitindonos de esta manera procesar la informacin que el usuario ha introducido. Al disear un formulario debemos indicar la pgina PHP que procesar el formulario, as como en mtodo por el que se le pasar la informacin a la pgina. enviardatosconformulario.html <html> <head> <title>Ejemplo de PHP</title> </head> <body> <h1>ejemplo de procesado de formularios</h1> Introduzca su nombre: <form action="procesa.php" method="get"> <input type="text" name="nombre"><br> <input type="submit" value="enviar"> </form> </body> </html> Al pulsar el botn enviar el contenido de cuadro de texto es enviado a la pgina que indicamos en el atributo action de la etiqueta form. En versiones anteriores a 4.2.0 PHP creaba una variable por cada elemento del FORM, esta variable creada tena el mismo nombre que el cuadro de texto de la pgina anterior y el valor que habamos introducido. Pero por razones de seguridad a partir de entonces para acceder a las variables del formulario hay que usar el array de parmetros $_POST[] o $_GET[] dependiendo del mtodo usado para enviar los parmetros.

Manual de PHP

11

En este ejemplo se ha creado una entrada en el array $_GET[] con el ndice 'nombre' y con el valor que haya introducido el navegante. procesa.php <html> <head> <title> Ejemplo de procesado de formularios</title> </head> <body> <h1>Ejemplo de procesado de formularios</h1> El nombre que ha introducido es: <?php echo $_GET['nombre'] ?> <br> </body> </html>

Mtodos GET y POST


Anteriormente hemos comentado que los datos de un formulario se envan mediante el mtodo indicado en el atributo method de la etiqueta form, los dos mtodos posibles son GET y POST. La diferencia entre estos dos mtodos radica en la forma de enviar los datos a la pgina, mientras que el mtodo GET enva los datos usando la URL, el mtodo POST los enva por la entrada estndar STDIO. metodoget.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Procesa el Mtodo GET[ ]</title> </head> <body> <h1>Ejemplo de procesado de formularios </h1> <form action="procesa2.php" method="get"> Introduzca su nombre:<input type="text" name="nombre"><br> Introduzca sus apellidos:<input type="text" name="apellidos"><br> <input type="submit" value="enviar"> </form> </body> </html> metodopost.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Procesa el Mtodo POST[ ]</title> </head> <body> <h1>Ejemplo de procesado de formularios </h1> <form action="procesa2.php" method="post"> Introduzca su nombre:<input type="text" name="nombre"><br> Introduzca sus apellidos:<input type="text" name="apellidos"><br> <input type="submit" value="enviar"> </form> </body> </html> procesa2.php <html> <head> <title>Procesa los Mtodos GET[ ] y POST[ ]</title> </head> <body> <h1>Ejemplo de procesado de formularios</h1> El nombre que ha introducido por GET es: <?php echo $_GET['nombre']," ",$_GET['apellidos'] ?><br> El nombre que ha introducido por POST es: <?php echo $_POST['nombre']," ",$_POST['apellidos'] ?> <br> </body> </html>

Manual de PHP

12

El resultado final es el mismo, slo que con el mtodo GET podemos ver los parmetros pasados ya que estn codificados en la URL.

Ms informacin sobre Formularios con PHP


Los Formularios no forman parte de PHP, sino del lenguaje estndar de Internet, HTML, pero como stos van a aparecer muchas veces durante el curso, vamos a dedicar esta algunas lneas a ellos. Lo que viene a continuacin es HTML y no PHP. Todo formulario comienza con la etiqueta <form action="lo_que_sea.php" method="post/get">. con . Con action indicamos el script que va procesar la informacin que recogemos en el formulario, mientras que method nos indica si el usuario del formulario va a enviar datos (post) o recogerlos (get). La etiqueta <form> indica el final del formulario. A partir de la etiqueta <form> vienen los campos de entrada de datos que pueden ser:

Cuadro de texto:
<input type="text" name="nombre" size="20" value="jose">

Cuadro de texto con barras de desplazamiento:


<textarea rows="5" name="descripcion" cols="20">Es de color rojo</textarea>

Casilla de verificacin:
<input type="checkbox" name="cambiar" value="ON">

Botn de opcin:
<input type="radio" value="azul" checked name="color">

Men desplegable:
<select size="1&qu class="codigo"><select size="1" name="dia"> <option selected value="lunes">Lunes</option> <option>martes</option> <option value="miercoles">Mircoles</option> </select>

Botn de comando:
<input type="submit" value="enviar" name="enviar">

Campo oculto:
<input type="hidden" name="edad" value="55"> Este ltimo tipo de campo resulta especialmente til cuando que remos pasar datos ocultos en un formulario. Como habrs observado todos los tipos de campo tienen un modificador llamado name, que no es otro que el nombre de la variable con la cual recogeremos los datos en el script indicado por el modificador action de la etiqueta form, con value establecemos un valor por defecto. A continuacin veamos un ejemplo, para lo cual crearemos un formulario en HTML como el que sigue y lo llamaremos aficiones.html: aficiones.html <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Aficiones</title> </head> <body> <form method="post" action="misdatos.php"> <input type="hidden" name="edad" value="55"> <p>Tu nombre <input type="text" name="nombre" size="30" value=""></p> <p>Tu sistema favorito <select size="1" name="sistema"> <option selected value="Linux">Linux</option> <option value="Unix">Unix</option> <option value="Macintosh">Macintosh</option>

Manual de PHP
<option value=&qmargin-left: 75"><option value="Windows">Windows</option> </select></p> <p>Te gusta el futbol? <input type="checkbox" name="futbol" value="on"></p> <p>Cul es tu sexo?</p> <blockquote> <p>Hombre:<input type="radio" name="sexo" value="hombre" checked /></p> <p>Mujer: <input type="radio" name="sexo" value="mujer"></p> </blockquote> <p>Aficiones</p> <p><textarea rows="5" name="aficiones" cols="28"></textarea></p> <p><input type="submit" value="Enviar datos" name="enviar"> <input type="reset" value="Restablecer" name="borrar"></p> </form> </body> </html> Y ahora creemos el script PHP llamado desde el formulario misdatos.php: misdatos.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Mis datos</title> </head> <body> <?php if ($enviar) { echo "Hola: <b>" . $nombre . "</b> que tal ests<br>\n"; echo "Eres: " . $sexo . "<br>\n"; echo "Tienes: " . $edad . "<br>\n"; echo "Tu sistema favorito es: " . $sistema . "<br>\n"; if ($futbol) { echo "Te gusta el ftbol <br> \n"; } else { echo "NO te gusta el ftbol <br>\n"; } if ($aficiones != "") { echo "Tus aficiones son: <br>\n"; echo nl2br($aficiones); } else { echo "NO tienes aficiones <br>\n"; } } echo "<a href='aficiones.html'>Volver al formulario</a>"; ?> </body> </html>

13

Una vez rellenados los datos del formulario, pulsamos el botn Enviar datos, con lo que le campo enviar toma lo que su etiqueta value indica, es decir enviar="Enviar datos". En nuestro script lo primero que evaluamos es que se haya enviado el formulario, y para ello nada mejor que comprobar que la variable $enviar no est vaca. Le ponemos el signo dlar delante a enviar, ponemos el signo dlar delante a enviar, ya que en PHP todas las variables se les refieren con este signo. Pero si fusionramos el cdigo de ambos fichero, nos ahorraramos uno. Si la variable $enviar est vaca, enviamos el formulario. fusionaficionesmisdatos.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>fusionar aficiones y misdatos</title> </head> <body> <?php if ($enviar) { echo "Hola <b>" . $nombre . "</b> que tal ests<br>\n";

Manual de PHP
echo "Eres: " . $sexo . "<br>\n"; echo "Tienes: " . $edad . "<br>\n"; echo "Tu sistema operativo favorito es: " . $sistema . "<br>\n"; if ($futbol) { echo "Te gusta el ftbol <br>\n"; } else { echo "NO te gusta el ftbol <br>\n"; } if ($aficiones != "") { echo "Tus aficiones son: <br>"; echo nl2br($aficiones); } else { echo "NO tienes aficiones.<br>"; } echo "<br><a href='$PHP_SELF'>Volver al formulario</a><br>"; } else { ?> <form method="post" action="<?php echo $PHP_SELF; ?>"> <input type="hidden" name="edad" value="55"> <p>Tu nombre <input type="text" name="nombre" size="30" size="30" value=""></p> <p>Tu sistema operativo favorito es: <select size="1" name="sistema"> <option selected value="Linux">Linux</option> <option value="Unix">Unix</option> <option value="Macintosh">Macintosh</option> <option value="Windows">Windows</option> </select></p> <p>Te gusta el futbol ? <input type="checkbox" name="futbol" value="on"></p> <p>Cul es tu sexo?</p> <blockquote> <p>Hombre: <input type="radio" value="hombre" name="sexo" checked /></p> <p>Mujer: <input type="radio" name="sexo" value="mujer" /></p> </blockquote> <p>Aficiones:</p> <p><textarea rows="5" name="aficiones" cols="28"></textarea></p> <p><input type="submit" value="Enviar datos" name="enviar"> <input type="reset" value="Restablecer" name="borrar"></p> </form> </body> </html> <?php } //fin If ?>

14

La variable de entorno $PHP_SELF, es una variable de entorno que nos devuelve el nombre del script que estamos ejecutando. Y por ltimo, hacer notar el uso de la funcin nl2br(), con la cual sustituimos los retornos de carro del texto, los cules reconocen los navegadores, por la etiqueta <br>.

Envo de Emails
PHP nos ofrece la posibilidad de enviar emails de una manera sencilla y fcil, para ello el lenguaje nos proporciona la instruccin mail( ) <?php mail(destinatario, tema, texto del mensaje); ?> En el parmetro destinatario pondremos la direccin de email a donde se enviar el mensaje, en el parmetro tema el tema o subject del mensaje y el parmetro texto del mensaje el cuerpo del mensaje en formato texto plano. Existe una sintaxis extendida de la instruccin mail() que nos permite aadir informacin adicional a la cabecera del mensaje. <?php mail(destinatario, tema, texto del mensaje, informacin adicional de cabecera); ?>

Manual de PHP

15

En la informacin de cabecera podremos incluir parmetros adicionales al mensaje como Reply-To:, From:, Content-type:.. que permiten tener un mayor control sobre el mensaje. formulariocorreo.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Formulario de correo con la funcin mail()</title> </head> <body> <h1>Ejemplo de envo de email</h1> Introduzca su direccin de email: <form action="email.php" method="get"> <input type="text" name="direccion"><br><br> Formato: <br> <input type="radio" name="tipo" value="plano" checked> texto plano<br> <input type="radio" name="tipo" value="html"> html<br><br> <input type="submit" value="Enviar"> </form> </body> </html> email.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title> Procesamiento de correo con la funcin mail()</title> </head> <body> <h1>Ejemplo de envo de email</h1> <? $direccion=$_GET['direccion']; $tipo=$_GET['tipo']; if ($direccion!=""){ if ($tipo=="plano"){ // Envo en formato texto plano mail($direccion, "Ejemplo de envo de email", "Ejemplo de envo de email de texto plano\n\n\n http://www.softedem.com/\n Manuales para desarrolladores web.\n","FROM: Pruebas <soporte@softedem.com>\n"); } else { // Envio en formato HTML mail($direccion, "Ejemplo de envo de email","<html><head><title> Manual de PHP</title></head><body>Ejemplo de envo de email de HTML<br><br>Seminario de Graduacin.<br>http://www.softedem.com/<br> <u>Manuales</u> para <b>desarrolladores</b> web.</body></html>","Content-type: text/html\n", "FROM: Pruebas <soporte@softedem.com>\n"); } echo "Se ha enviado un email a la direccin: ",$direccion," en formato <b>",$tipo,"</b>."; } ?> <br> </form> </body> </html>

Bases de Datos con MySQL y PHP


Para la realizacin de este curso sobre PHP con acceso a base de datos hemos elegido la base de datos MySQL por ser gratuita y por ser tambin la ms empleada en entornos UNIX, para lo cual el servidor donde tenemos alojadas las pginas nos tiene que proporcionar herramientas para crearla o acceso al Telnet para que la creemos por nosotros mismos. El comando para crear una base de datos MySQL es el siguiente: mysqladmin -u root create base_datos Con este comando conseguimos crear la una base de datos en el servidor de bases de datos de nuestro servidor. Una vez conseguido esto debemos crear las tablas en la base de datos, la descripcin de las tablas contienen la estructura de la informacin que almacenaremos en ellas. Para lo cual usaremos en lenguaje de consultas SQL comn para todas las bases de datos relacionales. Cree una base de datos con el nombre estudiantes. Para crear la tabla puede usar la herramienta de administracin de MySQL de su servidor web o puede escribir un fichero de texto con el contenido de la sentencia SQL equivalente y luego decirle al motor de base de datos que la ejecute. La instruccin para crear una tabla es la siguiente:

Manual de PHP
CREATE TABLE usuarios ( llave int(11) NOT NULL auto_increment, Nombre varchar(100), Apellidos varchar(100), Ciudad varchar(20), Sexo char(1), PRIMARY KEY (llave), UNIQUE llave(llave) );

16

Esta tabla puede ser creada con estas instrucciones o tambin se puede crear en software de interfaz grfica para MySQL como es el caso de SQLYog o PhpMyAdmin.

Conexin a Bases de Datos MySQL con PHP


Una vez que tenemos creada la base de datos en nuestro servidor, el siguiente paso es conectarnos a la misma desde una pgina PHP. Para ello PHP nos proporciona una serie de instrucciones para acceder a bases de datos MySQL. conecta.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Conexin con la base de datos</title> </head> <body> <?php function conectarse(){ $servidor = "localhost"; $usuario = "root"; $clave = "root"; $basedatos = "estudiantes"; if (!($link=mysql_connect($servidor, $usuario, $clave))){ echo "Error conectando al servidor de la base de datos: $basedatos"; exit(); } if (!mysql_select_db($basedatos,$link)){ echo "Error seleccionando la base de datos: $basedatos"; exit(); } return $link; } $link = conectarse(); echo "Conexin con la base de datos conseguida.<br />"; mysql_close($link); //cierra la conexin ?> </body> </html> Al ejecutar la instruccin mysql_connect creamos un vnculo entre la base de datos y la pagina PHP, este vnculo ser usado posteriormente en las consultas que hagamos a la base de datos. Finalmente, una vez que hemos terminado de usar el vnculo con la base de datos, lo liberaremos con la instruccin mysql_close para que la conexin no quede ocupada.

Consultas a la Base de Datos


Una vez que nos hemos conectado con el servidor de bases de datos, ya podemos realizar consultas a las tablas de la base de datos. Para facilitar la programacin hemos separado la funcin de conexin en una librera a parte, de tal manera que la incluiremos en todas las pginas que accedan a la base de datos. conectar.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Conexin con la base de datos</title> </head> <body>

Manual de PHP
<?php function conectarse(){ $servidor = "localhost"; $usuario = "root"; $clave = "root"; $basedatos = "estudiantes"; if (!($link=mysql_connect($servidor, $usuario, $clave))){ echo "Error conectando al servidor de la base de datos: $basedatos"; exit(); } if (!mysql_select_db($basedatos,$link)){ echo "Error seleccionando la base de datos: $basedatos"; exit(); } return $link; } $link = conectarse(); /*echo "Se realiz la conexin a la base de datos.<br />"; mysql_close($link); //cierra la conexin*/ ?> </body> </html> consulta1.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Mostrar Datos de una Tabla - Select</title> </head> <body> <h1>Mostrar Datos de una Tabla con PHP y MySQL</h1> <?php include("conectar.php"); $link=conectarse(); $result = mysql_query("select * from usuarios",$link); ?> <table border="1" cellspacing="0" cellpadding="1"> <tr><th>Nombre</th><th>Apellidos</th><th>Ciudad</th><th>Sexo</th></tr> <?php while($row = mysql_fetch_array($result)) { echo("<tr><td>$row[nombre]</td><td>$row[apellidos]</td><td>$row[ciudad]</td><td>$row[sexo]</td></tr>"); } mysql_free_result($result); mysql_close($link); ?> </table> </body> </html>

17

En este ejemplo hemos utilizado 3 instrucciones nuevas: mysql_query, mysql_fetch_array y mysql_free_result. Con la instruccin mysql_query hemos hecho una consulta a la base de datos en el lenguaje de consultas SQL, con la instruccin mysql_fetch_array extraemos los datos de la consulta a un array y con mysql_free_result liberamos la memoria usada en la consulta.

Insertar Registros
Hasta ahora nos hemos conectado a una base de datos y hemos hecho consultas a la misma, ahora presentaremos como introducir nuevo registros en la base de datos. Para ello usaremos un formulario y en el action del form <form action="programa.php"> indicaremos que debe ser procesado una pgina PHP, esta pgina lo que har ser introducir los datos del formulario en la base de datos. insertar.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Insertar Datos en la Base de datos</title> </head>

Manual de PHP
<body> <h1>Ejemplo de uso de bases de datos con PHP y MySQL</h1> <form action="procesar.php" method="get"> <table> <tr><td>Nombre:</td><td><input type="text" name="nombre" size="20" maxlength="30"></td></tr> <tr><td>Apellidos:</td><td><input type="text" name="apellidos" size="20" maxlength="30"></td></tr> <tr><td>Ciudad:</td><td><input type="text" name="ciudad" size="20" maxlength="30"></td></tr> <tr><td>Sexo:</td><td><input type="text" name="sexo" size="5" maxlength="30"></td></tr> <tr><td colspan="2"><input type="submit" name="accion" value="Grabar"></td></tr> </table> </form> <hr> <?php include("conectar.php"); $link=conectarse(); $result=mysql_query("select * from usuarios",$link); ?> <table border="1" cellspacing="0" cellpadding="2"> <tr><th>Nombre</th><th>Apellidos</th><th>Ciudad</th><th>Sexo</th></tr> <?php while($row = mysql_fetch_array($result)) { echo("<tr><td>$row[nombre]</td><td>$row[apellidos]</td><td>$row[ciudad]</td><td>$row[sexo]</td></tr>"); } mysql_free_result($result); mysql_close($link); ?> </table> </body> </html> procesar.php <?php header("Location: insertar.php"); ?> <html> <head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Inserta la datos en la tabla</title></head> <body> <?php include("conectar.php"); $link=conectarse(); $nombre=$_GET['nombre']; $apellidos=$_GET['apellidos']; $ciudad=$_GET['ciudad']; $sexo=$_GET['sexo']; mysql_query("insert into usuarios (nombre,apellidos,ciudad,sexo) values('$nombre','$apellidos','$ciudad','$sexo')",$link); ?> </body> </html>

18

La primera pgina PHP insertar.php es un formulario que nos permite introducir nombre y apellido, ciudad y sexo para aadirlo a la base de datos, seguido de una consulta que nos muestra el contenido de la tabla prueba. El formulario llama a la pgina procesar.php que aadir los datos a la tabla. La segunda pgina procesar.php se conecta a la base de datos y aade un nuevo registro con la instruccin insert del lenguaje de bases de datos SQL. Una vez el registro se ha aadido se vuelve a cargar la pgina insertar.php

Borrar Registros
Y finalmente, para cerrar el ciclo, nos queda el borrado de registros. El borrado de registros el uno de los procesos ms sencillos. Para indicar que elemento vamos a borrar hemos usado un enlace a la pgina borra.php pasndole el campo llave de cada registro, de esta manera la pgina borra.php sabe que elemento de la tabla ha de borrar. borrando.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Eliminar datos de una base de datos</title>

Manual de PHP
</head> <body> <h1>Ejemplo de uso de bases de datos con PHP y MySQL</h1> <?php include("conectar.php"); $link=conectarse(); $result=mysql_query("select * from usuarios",$link); ?> <table border=1 cellspacing=0 cellpadding=1> <tr><th>Nombre</th><th>Apellidos</th> <th>Borrar</th></tr> <?php while($row = mysql_fetch_array($result)) { echo("<tr><td>$row[nombre]</td><td>$row[apellidos]</td><td><a href='borrar.php?llave=$row[llave]'>Borrar</a></td></tr>"); } mysql_free_result($result); mysql_close($link); ?> </table> </body> </html> borrar.php <?php header("Location: borrando.php"); include("conectar.php"); $link=conectarse(); $id=$_GET['llave']; mysql_query("delete from usuarios where llave = ".$id,$link); ?>

19

La pgina borrar.php se conecta a la base de datos y borra el registro indicado en la variable $id que ha sido pasado desde la pgina borrando.php. Una vez el registro se ha borrado se vuelve a cargar la pgina borrando.php.

Actualizar Registros
Para mostrar cmo se actualiza un registro presente en nuestra base de datos, vamos a hacerlo a partir de un caso un poco ms complejo para que empecemos a familiarizarnos con estas operaciones. Realizaremos un par de scripts que permitan cambiar el nmero de telfono de las distintas personas presentes en nuestra base. El nombre de estas personas, as como el nuevo nmero de telfono, sern recogidos por medio de un formulario. El archivo del formulario va a ser esta vez un script PHP en el que efectuaremos una llamada a nuestra base de datos para construir un men desplegable donde aparezcan todos los nombres. La cosa quedara as: actualizar1.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Actualizar datos de una Base de Datos</title> </head> <body> <h1 align="center">Actualizar un registro</h1> <?php include("conectar.php"); $link=conectarse(); echo "<form method='post' action='actualizar2.php'>"; //Creamos la sentencia SQL y la ejecutamos $consulta="Select nombre From usuarios Order By nombre"; $result=mysql_query($consulta,$link); ?> <table width="380" border="0" align="center" cellpadding="2" cellspacing="0"> <tr> <td width="217" align="left">Nombre del usuario a cambiar: </td> <td width="7">&nbsp;</td> <td width="144"><?php echo "<select name='nombrebusqueda'>"; //Generamos el men desplegable

Manual de PHP
while ($row=mysql_fetch_array($result)){ echo "<option>". $row['nombre'] ."</option>"; } echo "</select>"; ?> </td> </tr> <td align="left">Nombre: </td><td>&nbsp;</td><td><input type="text" name="nombre"></td> </tr> <tr> <td align="left">Apellidos: </td><td>&nbsp;</td><td><input type="text" name="apellidos"></td> </tr> <tr> <td align="left">Ciudad: </td><td>&nbsp;</td><td><input type="text" name="ciudad"></td> </tr> <tr> <td align="left">Sexo: </td><td>&nbsp;</td><td><input type="text" name="sexo"></td> </tr> <tr> <td colspan="3" align="center"><input type="submit" value="Actualizar"></td> </tr> </table> </form> </body> </html>

20

La manera de operar para construir el men desplegable es la misma que para visualizar la tabla. De nuevo empleamos un bucle while en combinacin con la funcin mysql_fetch_array lo que nos permite mostrar cada una de las opciones. El script de actualizacin ser muy parecido al de insercin: actualizar2.php <?php header("Location: consulta1.php"); ?> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Actualizar datos de una Base de Datos</title> </head> <body> <?php include("conectar.php"); $link=conectarse(); $nombrebusqueda=$_POST['nombrebusqueda']; $nombre=$_POST['nombre']; $apellidos=$_POST['apellidos']; $ciudad=$_POST['ciudad']; $sexo=$_POST['sexo']; //Creamos la sentencia SQL y la ejecutamos $consulta="Update usuarios Set nombre='$nombre', apellidos='$apellidos', ciudad='$ciudad', nombre='$nombrebusqueda'"; mysql_query($consulta,$link); ?> <h1><div align="center">Registro Actualizado</div></h1> <div align="center"><a href="consulta1.php">Visualizar el contenido de la base de datos</a></div> </body> </html>

sexo='$sexo'

Where

Realizar Bsquedas
Para realizar bsquedas necesitamos insertar las siguientes instrucciones. busqueda1.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Opciones de Bsqueda</title> </head>

Manual de PHP
<body> <h1>Opciones de Bsqueda</h1> <p>Buscar por:</p> <form name="form1" method="post" action="busqueda2.php"> <label for="radiobutton">Id</label> <input name="opcion" type="radio" id="opcion" value="id" />&nbsp;&nbsp;&nbsp; <label for="radiobutton">Nombre</label> <input name="opcion" type="radio" id="opcion" value="nombre" checked /> &nbsp;&nbsp;&nbsp; <label for="radiobutton">Apellidos</label> <input name="opcion" type="radio" id="opcion" value="apellidos" />&nbsp;&nbsp;&nbsp; <label for="radiobutton">Nombre contenga...</label> <input name="opcion" type="radio" id="opcion" value="contenga" />&nbsp;&nbsp;&nbsp; <label for="radiobutton">Sexo</label> <input name="opcion" type="radio" id="opcion" value="sexo" /> <p>Escriba el valor que est&aacute; buscando: <input name="valor" type="text" id="valor" /></p> <p><input type="submit" name="submit" value="Buscar Registro" /></p> </form> </body> </html> busqueda2.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Buscar en una tabla</title> </head> <body> <?php include("conectar.php"); $link=conectarse(); $valor=$_POST['valor']; if ($_POST['opcion']=="id"){ echo "Se seleccion la opcin id <br>"; $result=mysql_query("select * from usuarios where llave='$valor'",$link); } if ($_POST['opcion']=="nombre"){ echo "Se seleccion la opcin nombre <br>"; $result=mysql_query("select * from usuarios where nombre = '$valor'",$link); } if ($_POST['opcion']=="apellidos"){ echo "Se seleccion la opcin Apellidos <br>"; $result=mysql_query("select * from usuarios where apellidos = '$valor'",$link); } if ($_POST['opcion']=="contenga"){ echo "Se seleccion la opcin Nombre contenga...<br>"; $result=mysql_query("select * from usuarios where nombre like '%$valor%'",$link); } if ($_POST['opcion']=="sexo"){ echo "Se seleccion la opcin Sexo<br>"; $result=mysql_query("select * from usuarios where sexo = '$valor'",$link); } ?> <table border="1" cellspacing="0" cellpadding="2"> <tr><th>Nombre</th><th>Apellidos</th><th>Ciudad</th><th>Sexo</th></tr> <?php while($row = mysql_fetch_array($result)) { echo("<tr><td>$row[nombre]</td><td>$row[apellidos]</td><td>$row[ciudad]</td><td>$row[sexo]</td></tr>"); } mysql_free_result($result); mysql_close($link); ?> </table> <a href="busqueda1.php">Nueva bsqueda</a> </body> </html>

21

Manual de PHP

22

Esta bsqueda permite seleccionar diferentes campos. Le quedar como tarea realizar bsquedas por ciudad. (Nota: utilice la instruccin LIKE de SQL).

Restringir el Acceso
En esta seccin vamos a explicar cmo podemos restringir el acceso a segn qu pginas, para que slo las personas autorizadas puedan acceder a ciertas partes del nuestro sitio web. Atencin: El acceso restringido a pginas usando las variables globales $PHP_AUTH_USER, $PHP_AUTH_PW y $PHP_AUTH_TYPE slo funciona si PHP ha sido instalado como un mdulo de Apache, si ha sido instalado como un CGI los ejemplos de sta seccin no funcionarn. Para conseguir la autentificacin en las pginas usaremos el sistema de autentificacin del protocolo HTTP, este sistema se basa en las variables globales $PHP_AUTH_USER y $PHP_AUTH_PW. $PHP_AUTH_USER. Nombre de usuario introducido. $PHP_AUTH_PW. Contrasea introducida. Para que el navegador nos muestre la ventana de peticin de nombre de usuario y contrasea basta con enviar la siguiente cabecera: abrirventanaautenticacion.php <?php if (!isset($PHP_AUTH_USER)) { header('WWW-Authenticate: Basic realm="Acceso restringido"'); header('HTTP/1.0 401 No Autorizado'); echo "Autorizacin Requerida."; exit; } else { echo "Ha introducido el nombre de usuario: $PHP_AUTH_USER<br>"; echo "Ha introducido la contrasea: $PHP_AUTH_PW<br>"; } ?> Esto provoca que se muestre la ventana de nombre de usuario y contrasea y los datos introducidos se asignen a las variables $PHP_AUTH_USER y $PHP_AUTH_PW. A partir de aqu realizaremos las comprobaciones necesarias para asegurarnos que los datos introducidos son los correctos. En el siguiente ejemplo pediremos autorizacin y comprobaremos si el nombre de usuario es Joe y la contrasea es 123, si es as tendremos acceso al resto de la pgina. restringiracceso.php <?php if (($PHP_AUTH_USER!="diego") || ($PHP_AUTH_PW!="12345")) { header("WWW-Authenticate: Basic realm='Acceso restringido.'"); header('HTTP/1.0 401 No Autorizado'); echo "Autorizaci&oacute;n Requerida"; exit; } ?> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Restringir acceso</title> </head> <body> Ha conseguido el acceso a la <b>zona restringida</b>. </body> </html>

Distincin de Usuarios
En la anterior pgina todo el mundo que tena acceso a la parte restringida entraba con el mismo nombre de usuario y contrasea, esto evidentemente no es una buena solucin, es mejor que cada persona tenga un nombre de usuario y contrasea, ya que de esta forma podemos inhabilitar a un usuario sin ver comprometida la seguridad de nuestro sitio.

Manual de PHP

23

En esta pgina veremos la forma de realizar esto, teniendo un fichero separado con los nombres de usuario y las contraseas vlidas. Dicho fichero podra tener el siguiente formato: nombre_de_usuario|contrasea. Por ejemplo: passwords.txt Joe|1235 Pedro|qwer Noe|Gty45e kermit|rwe4v En este ejemplo se pide la autorizacin al comienzo de la pgina si no se ha establecido con anterioridad y se comprueba con el fichero de contraseas que hemos llamado passwords.txt, si el nombre de usuario y contrasea coincide con alguna entrada del fichero se nos permite ver el resto de la pgina. distinciondeusuarios.php

<?php if (!isset($PHP_AUTH_USER)) { header('WWW-Authenticate: Basic realm="Acceso restringido"'); header('HTTP/1.0 401 No Autorizado'); echo 'Autorizacin Requerida'; exit; } $fich = file("passwords.txt"); $i=0; $validado=false; while ($fich[$i] && !$validado) { $campo = explode("|",$fich[$i]); if (($PHP_AUTH_USER==$campo[0]) && ($PHP_AUTH_PW==chop($campo[1]))) $validado=true; $i++; } if (!$validado) { header('WWW-Authenticate: Basic realm="Acceso restringido"'); header('HTTP/1.0 401 No Autorizado'); echo 'Autorizacin Requerida'; exit; } ?> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Distincin de Usuarios</title> </head> <body> Ha conseguido el acceso a la zona restringida con el usuario <strong><?php echo $PHP_AUTH_USER ?></strong>. </body> </html>

Autentificacin HTTP con PHP


Las caractersticas de autentificacin HTTP en PHP slo estn disponibles cuando se est ejecutando como un mdulo en Apache y hasta ahora no lo estn en la versin CGI. En un script PHP como mdulo de Apache, se puede usar la funcin header() para enviar un mensaje de "Autentificacin requerida" al navegador cliente haciendo que muestre una ventana de entrada emergente con nombre de usuario y contrasea. Una vez que el usuario ha rellenado el nombre y la contrasea, la URL que contiene el script PHP ser llamada de nuevo con las variables predefinidas PHP_AUTH_USER, PHP_AUTH_PW, y AUTH_TYPE asignadas con el nombre de usuario, la contrasea y el tipo de autentificacin respectivamente. Estas variables predefinidas se pueden encontrar en las matrices $_SERVER y $HTTP_SERVER_VARS. Slo autentificacin "Bsica" est soportada en este momento. Un script de ejemplo que fuerce la autentificacin del cliente en una pgina sera como el siguiente: forzarautenticacion.php <?php if (!isset($_SERVER['PHP_AUTH_USER'])) { header('WWW-Authenticate: Basic realm="My Realm"'); header('HTTP/1.0 401 Unauthorized'); echo 'Texto que se enva al hacer clic en el botn Cancelar'; exit;

Manual de PHP
} else { echo "<p>Hola {$_SERVER['PHP_AUTH_USER']}.</p>"; echo "<p>Ingresaste con el Password: {$_SERVER['PHP_AUTH_PW']}</p>"; } ?>

24

En vez de, sencillamente, mostrar PHP_AUTH_USER y PHP_AUTH_PW, seguramente deseas comprobar la validez del nombre de usuario y contrasea. Tal vez enviando una consulta a una base de datos o buscando el usuario en un fichero dbm. Vigilar aqu los navegadores Interner Explorer con bugs. Parecen muy quisquillosos con el orden de las cabeceras. Enviar la cabecera WWW-Autentificacin antes que la cabecera HTTP/1.0 401 parece ser el truco por ahora. En fecha de la versin PHP 4.3.0, para prevenir que alguien escriba un script que revele la contrasea de una pgina que ha sido autentificada a travs de algn mecanismo externo tradicional, las variables PHP_AUTH no sern asignadas si algn tipo de autentificacin externa ha sido activada para la pgina en particular. En este caso, la variable REMOTE_USER puede ser usada para identificar al usuario autentificado externamente. As que se puedes utilizar $_SERVER['REMOTE_USER']. Tanto Netscape como Internet Explorer borrarn la cach de la ventana de autentificacin en el navegador local despus de recibir una respuesta 401 del servidor. Esto puede usarse, de forma efectiva, para "desconectar" a un usuario, forzndole a reintroducir su nombre y contrasea. Algunas personas usan esto para "hacer caducar" entradas, o para proveer un botn de "desconectar". caducarentradas.php <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Caducar entradas</title> </head> <body> <?php function authenticate() { @header('WWW-Authenticate: Basic realm="Test Authentication System"'); @header('HTTP/1.0 401 Unauthorized'); echo "Debe ingresar un usuario y una contrasea vlidos."; exit; } if (!isset($_SERVER['PHP_AUTH_USER']) || ($_POST['SeenBefore'] == 1 && $_POST['OldAuth'] == $_SERVER['PHP_AUTH_USER'])) { authenticate(); } else { echo "<p>Bienvenido: $_SERVER[PHP_AUTH_USER]<br>"; echo "Anterior: $_REQUEST[OldAuth]"; echo "<form action=$_SERVER[PHP_SELF] method='post'>"; echo "<input type='hidden' name='SeenBefore' value='1'>"; echo "<input type='hidden' name='OldAuth' value=$_SERVER[PHP_AUTH_USER]>"; echo "<input type='submit' value='Reingresar usuario'>"; echo "</form></p>\n"; } ?> </body> </html> Este comportamiento no es requerido por el estndar de autentificacin bsica de HTTP, por lo que nunca debe depender de esto. Pruebas con Lynx han demostrado que Lynx no borra las credenciales de autentificacin con una respuesta 401 del servidor, por lo que pulsando atrs y despus adelante abrira el recurso de nuevo (siempre que los requerimientos de contrasea no hayan cambiado). Adems tener en cuenta que hasta la versin de PHP 4.3.3, la autentificacin HTTP no funcionaba con el servidor IIS de Microsoft y la versin CGI de PHP, debido a una limitacin de IIS. Para que funcione a partir de PHP 4.3.3, debes de editar tu configuracin sobre "Seguridad en directorios" en IIS. Pulsar en 'Editar" y elegir solamente "acceso annimo", todos los dems campos no se deben de elegir.

Subir Archivos al Servidor


Para el correcto aprendizaje utilizaremos un ejemplo, en l que subiremos un archivo. Este solo puede ser de extencion .zip y ocupar menos de 30 kb, definiendo as las opciones del upload con php.

Manual de PHP
Primero empezaremos con el formulario html, encargado de enviar el archivo al servidor. subirarchivo.php <html> <head> <title>Subir archivos al servidor</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> </head> <body> <h1>Subir archivo al Servidor</h1> <p>Seleccione el archivo que desea subir al servidor (Menor de 30 Kb):<br></p> <form action="subir.php" method="post" name="miformu" enctype="multipart/form-data"> <p><input name="archivo" type="file"></p> <p><input type="submit" value="Subir Archivo" ></p> </form> </body> </html>

25

Cmo se darn cuenta, este formulario tiene un parmetro nuevo llamado enctype, con el valor "multipart/form-data", informando que enva datos y archivos, opcin indispensable para el correcto upload del fichero. Tambin utilizamos un input "file" para que el usuario pueda explorar su respectiva computadora en busca del archivo a subir. Suponemos que el script al que enviamos el formulario y el encargado de procesarlo se llama subir.php. A continuacin explicare el contenido y funcionamiento de este archivo. Cmo vimos en el formulario, el campo de archivo se llama archivo: <input name="archivo" type="file"> De acuerdo a este nombre sera que trabajaremos en el lado del servidor, osea en el script. El archivo se guarda en la carpeta temporal del servidor, dato que hay que tenerlo en cuenta ya que no todos los servidores cuentan con esta opcin y ponen el tamao de dicha carpeta a 0, imposibilitando subir archivos. Para referirnos al archivo en el script lo hacemos por medio de: $archivo Otras propiedades que tendremos a nuestra disposicin son el tamao (en bytes) y el nombre del archivo. $archivo_name - Nombre del archivo (ej.: instaladores.zip, miarchivo.zip) $archivo_size - Tamao del archivo en bytes (si son 10kb serian 10000 bytes) Nota: A este punto cundo nos referimos al archivo lo hacemos siempre con $archivo, debido a que en el formulario lo denominamos de esta forma (<input name="archivo" type="file">). La explicacin la hago suponiendo un conocimiento bsico de php por parte del lector. Primero mostrare el script, luego explicare lnea por lnea el script: subir.php <?php $extension = explode(".",$archivo_name); $num = count($extension)-1; if($extension[$num] == "zip") { if($archivo_size < 30000) { if(!copy($archivo, "archivos/".$archivo_name)) { echo "Error al copiar el archivo"; } else { echo "Archivo subido con xito";} } else { echo "El archivo supera los 30kb";} } else { echo "El formato de archivo no es vlido, solo .zip";} ?> Lo primero que haremos ser comprobar que la extensin del archivo es la permitida (.zip).

Manual de PHP

26

Para ello utilizamos la funcion de php explode, la cual guardar en un array el nombre del archivo segn el primer parmetro (el punto): $extension = explode(".",$archivo_name); Para mejor entendimiento, si el archivo se llama ficheros.zip el explode pondra en este caso en la variable $extension el nombre en dos partes: $extension[0] y $extension[1] los cuales contienen: $extension[0] --> "ficheros" $extension[1] --> "zip" Ahora obtendremos la longitud del array, en este caso sera de 2 (ya que contiene 2 elementos "ficheros" y "zip"), a ese nmero le mermamos 1 y lo asignamos a una variable llamada $num: $num = count($extension)-1; Nota: Le hemos mermado 1 a la longitud por que cuando queramos llamar al array $extension[$num] debemos de hacerlo teniendo en cuenta que los elementos van desde 0, por lo que aunque contenga 2 elementos no podemos llamar al segundo con $extension[2], si no que tenemos que llamarlo por su posicin $extencion[1]. Ahora haremos el condicional. Si la extensin del archivo es zip continuaremos con el proceso de upload, de lo contrario mostraremos mensaje de error. if($extension[$num] == "zip") {...} else { echo "el formato de archivo no es vlido, solo .zip"; } Ahora, continuaremos con el upload, suponiendo que el archivo era el correcto. Lo siguiente a hacer es comprobar el tamao del archivo; para ello utilizaremos la variable antes mencionada $archivo_size. Si el tamao es menor a los 30kb (recuerde, debe especificarlo en bytes, por lo que serian 30000) continuaremos con el upload, de lo contrario mostraremos un mensaje de error: if($archivo_size < 30000) {...} else { echo "el archivo supera los 30kb"; } Ahora, continuaremos con el upload, suponiendo que el tamao del archivo es correcto. Utilizaremos la funcin copy() de php, la cual copiara el archivo a la carpeta que especifiquemos. Nota: El archivo que hemos subido por medio del formulario se guarda en la carpeta temporal del servidor y se accede a l por medio de la variable $archivo, este archivo ser borrado de la carpeta temporal cuando el script finalice su ejecucin, este proceso es automtico y lo realiza el servidor, usted no tiene que preocuparse por este aspecto. En este caso copiaremos el archivo a una carpeta del servidor llamada archivos. Ntese que la ruta de copiado debe de ser relativa, no absoluta, y es relativa al script. O sea, si el script se ejecuta en: http://www.servidor.net/cuenta/carpeta/subir.php La funcin en este caso intentara copiarlo a: http://www.servidor.net/cuenta/carpeta/archivos/ Lo hemos puesto en un if y con signo de negacin (!), para que en caso de no poder copiar el archivo nos salga mensaje de error: if(!copy($archivo, "archivos/".$archivo_name)) { echo "error al copiar el archivo"; } else { echo "archivo subido con exito"; }

Manual de PHP

27

En este caso el archivo ha sido copiado a la carpeta archivos y con el mismo nombre que tena, o sea, si el archivo se llamaba "ficheros.zip", el archivo ha quedado en la carpeta con el mismo nombre "archivos/ficheros.zip". Ntese que esto no es obligatorio, y podemos ponerle el nombre que queramos, si hubiramos querido que el archivo se llamara "jlmm.zip", simplemente pondramos en el copy() lo siguiente: copy($archivo, "archivos/jlmm.zip")

Sesiones Qu son Sesiones?


Si existe una consulta repetida en las listas de PHP, es la relativa al uso de las sesiones. El uso de sesiones es un mtodo ampliamente extendido en cualquier aplicacin de cierta entidad. Bsicamente una sesin es la secuencia de pginas que un usuario visita en un sitio web. Desde que entra en nuestro sitio, hasta que lo abandona. El trmino sesin en PHP, session en ingls, se aplica a esta secuencia de navegacin, para ello crearemos un identificador nico que asignamos a cada una de estas sesiones de navegacin. A este identificador de sesin se le denomina, comnmente, como la sesin. El proceso en cualquier lenguaje de programacin podra ser algo as: Existe una sesin? Si existe la retomamos Si no existe creamos una nueva Generar un identificador nico Y para que no perdamos el hilo de la navegacin del usuario deberemos asociar esta sesin a todas las URLs y acciones de formulario. Podemos tambin crear un cookie que incluya el identificador de sesin, pero es conveniente recordar que la disponibilidad o no de las cookies depende del usuario, y no es conveniente fiarse de lo que un usuario pueda o no tener habilitado. Lo contado hasta ahora es teora pura y es aplicable a cualquier lenguaje de programacin C, Perl, etc. Los que programamos en PHP4 tenemos la suerte de que toda la gestin de sesiones la hace el mismo PHP.

Inicializar una Sesin


Para utilizar sesiones en PHP lo primero es inicializarlas. Podemos hacerlo explcitamente, mediante la funcin session_start(), o al registrar una variable en una sesin mediante session_register('miVariable'). En ambos casos se crea una nueva sesin, si no existe, o se retoma la sesin actual. Veamos un sencillo ejemplo: iniciarsesion.php <?php session_start(); echo "He inicializado la sesin"; ?> Esta es la forma ms bsica, si el usuario tiene los cookies activados, PHP habr insertado de forma automtica la sesin y sta ser pasada de una pgina a otra sin hacer nada ms. Desde un punto de vista prctico la sesin es operativa, pero no vemos nada. Podemos obtener la sesin en cualquier momento mediante la funcin session_id(). Inserta en las sucesivas pginas la siguiente lnea para ver si la sesin est disponible: <?php session_start(); echo 'La sesin actual es: '.session_id(); ?> En este caso session_start() comprueba en los cookies que existe una sesin y continua con ella, session_id() devuelve el identificador actual.

Caso Prctico
Veamos otro ejemplo que, tal vez, te lo aclare un poco ms: contarsesiones.php <?php session_register('contador'); echo '<a href="'.$PHP_SELF.'?'.$SID.'">Contador vale: ' .++$_SESSION['contador']. '</a>'; ?>

Manual de PHP

28

Como dije anteriormente la sesin se crea o recoge mediante session_start(), o tambin cuando se registra una variable de sesin mediante session_register(). Si no has utilizado nunca las sesiones, el concepto de variable de sesin, puede resultar un poco abstracto. Bsicamente es una variable, como cualquiera de las que gestiona PHP4, pero que reside en un espacio especfico en el servidor, junto con el identificador de sesin, y que pertenece nicamente a un usuario. En nuestro ejemplo anterior, registramos la variable $contador en la primera lnea del script. En la segunda lnea, entre otras cosas, cada vez que recarguemos la pgina o hagamos click sobre el enlace, el valor de $contador se incrementar en 1. En esta lnea hacemos uso de la variable reservada $PHP_SELF, que hace referencia al propio script en ejecucin y una constante propia de PHP4, $SID, que contiene el nombre de la sesin y el identificador de la misma. Podemos averiguar tambin el nombre de la sesin, o modificarlo, mediante la funcin session_name(). Veamos una prueba prctica: modificarnombresesion.php <?php session_name('misesion'); session_register('contador'); echo '<a href="'.$PHP_SELF.'?'.SID.'">Contador vale: '.++$_SESSION['contador'].'</a><br>'; echo 'Ahora el nombre es '.session_name().' y la sesin '.$misesion.'<br>'; ?> La asignacin del nombre de sesin debe realizarse antes que ninguna otra funcin con sesiones, antes que session_start() o session_register().

Error Comn
Uno de los errores ms comunes cuando se utilizan sesiones es dejar lneas en blanco antes de la inicializacin de PHP o enviar alguna salida a la pantalla. Para probarlo crea una lnea en blanco o con cualquier cosa antes de <?php. Si tienes los cookies activados, te encontrars un error de este tipo: Warning: Cannot send session cookie - headers already sent by (output started at /home/session.php:2) in /home/session.php on line 4 PHP est informando de que no puede activar los cookies en el navegador del usuario, porque las cabeceras ya han sido enviadas. Simplemente por la existencia de una lnea en blanco. Como medida prctica, no dejes espacios ni antes del inicio del script, ni despus de la finalizacin.

Te ahorrar muchos disgustos.


Si despus de todo lo comentado an no entiendes para que sirven las sesiones, veamos un ejemplo prctico. Imagina que quisieras crear un sistema de cesta de la compra...

Carrito de Compras
Si despus de todo lo comentado an no entiendes para que sirven las sesiones, veamos un ejemplo prctico. Imagina que quisieras crear un sistema de cesta de la compra, en su forma bsica podra ser algo as: carritodecompras.php <?php session_start(); session_register('itemsEnCesta'); $item=$_POST['item']; $cantidad=$_POST['cantidad']; $itemsEnCesta=$_SESSION['itemsEnCesta']; if ($item){ if (!isset($itemsEnCesta)){ $itemsEnCesta[$item]=$cantidad; }else{ foreach($itemsEnCesta as $k => $v){ if ($item==$k){ $itemsEnCesta[$k]+=$cantidad; $encontrado=1; } } if (!$encontrado) $itemsEnCesta[$item]=$cantidad; }

Manual de PHP
} $_SESSION['itemsEnCesta']=$itemsEnCesta; ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Documento sin t&iacute;tulo</title> </head> <body> <tt> <form action="<?=$PHP_SELF."?".$SID?>" method="post"> Dime el producto: <input type="text" name="item" size="20"><br> Cuntas unidades: <input type="text" name="cantidad" size="20"><br> <input type="submit" value="Aadir al Carrito"><br> </form> <? if (isset($itemsEnCesta)){ echo'El contenido de la cesta de la compra es:<br>'; foreach($itemsEnCesta as $k => $v){ echo 'Artculo: '.$k.' ud: '.$v.'<br>'; } } ?> </tt> </body> </html>

29

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-

Una breve explicacin. En la lnea 4 comprobamos si el usuario ha pasado algn artculo, desde el formulario. En la 5 si el array itemsEnCesta no existe, lo creamos con el nuevo producto y la cantidad indicada. Si el array existe recorremos su contenido, entre las lneas 8 y 13, y si encontramos un artculo igual, aadimos la cantidad en la lnea 10. Si no lo encontramos, es un nuevo artculo, por lo tanto, aadimos el nuevo producto con la correspondiente cantidad a itemsEnCesta en la lnea 14. Y a continuacin imprimimos el formulario y los resultados, si los hubiera, a partir de la lnea 18, donde empieza el HTML. Te imaginas las posibilidades de un sistema de almacenamiento de informacin de estas caractersticas?. No necesitas ficheros, ni bases de datos, ni tienes que andar pasando valores de una pgina a otra. PHP va gestionando estos datos por nosotros, hasta el momento en que decidamos almacenar la informacin donde ms nos interese. Estas son las funcionalidades bsicas de las sesiones, espero que te haya resultado ilustrativo y no olvides consultar el resto de funciones asociadas al uso de sesiones en el manual de PHP.

Uso de Cookies
PHP permite manejar cookies con gran sencillez. Las cookies son pequeos archivos de texto que nuestra pgina puede almacenar en el disco duro de los visitantes, y recuperar cuando vuelvan a visitarla. La principal utilidad de las cookies (galletas) es la de solventar el problema de la falta de estado en la navegacin a travs de las pginas web. Con las cookies, pequeas porciones de informacin se quedan registradas en el navegador permitiendo identificar a este a travs de diferentes pginas de un mismo sitio e incluso durante visitas entre distintos das. Realmente las cookies no son ms que cadenas de texto que son enviadas desde el servidor al cliente (navegador) y almacenadas en este, luego el navegador enva estas cookies al servidor permitiendo as la identificacin del cliente en el servidor. La cookie es enviada al navegador desde el servidor y si este la acepta permanece en l.

Las pginas piden la cookie al navegador...

Manual de PHP

30

El navegador las enva, permitiendo la identificacin del usuario por parte del servidor.

La funcin para colocar una cookie es setcookie(), y su sintaxis: setcookie(Nombre, Valor, Tiempo_Vida, Path, Dominio, Seguro); El primer parmetro es, pues, el nombre de la cookie. Es el nico valor estrictamente necesario, los dems son opcionales. As, si establecemos al principio de nuestro script <?php setcookie("saludo"); ?> Estamos lanzando una cookie llamada saludo, sin ningn valor. Automticamente se establecen los parmetros por defecto tiempo de vida = lo que dure la sesin; path = el directorio actual (dependiendo del navegador); dominio = el dominio de la pgina; seguro = no. Ten en cuenta que la instruccin para colocar la cookie ha de ir junto a las cabeceras http de la pgina, por tanto debes incluirla al comienzo del script, antes de que comience el volcado de html al usuario; de lo contrario dar error. Para completar los dos primeros parmetros nombre_cookie = valor utilizamos: <?php setcookie("saludo", "hola"); ?> El nombre y valor de la cookie viajan y se almacenan como texto simple, por lo que si deseas utilizar cookies para datos sensibles, por ejemplo la contrasea de usuario, es mejor encriptarla. Tambin debes tener en cuenta que no puedes usar en el nombre de la cookie el punto y coma (;), la coma (,) o espacios en blanco ( ). Tampoco es conveniente usar caracteres fuera del ASCII simple. Si precisas usar algunas de estas cosas puedes utilizar la funcin urlencode() En cuanto a la longitud de los datos, en general toda la cookie no debe exceder de 4 K. El tercer parmetro de la cookie es su tiempo de vida. Se especifica en segundos. Si no especificamos nada, slo dura la sesin (es decir, hasta que cerremos el navegador). Usamos la funcin time() seguida del nmero de segundos: duraciondelacookie.php <?php // Esta cookie dura una hora. 1 hora = 3600 segundos setcookie("visitas", "1", time() + 3600); // Esta cookie dura un dia. 24 h = 86400 segundos setcookie("visitas", "1", time() + 86400); // esta cookie dura una semana. setcookie("visitas", "1", time() + (7 * 86400) ); // esta cookie dura un ao. 1 ao = 31536000 segundos setcookie("visitas", "1", time() + 31536000); ?> El cuarto y quinto parmetros de la cookie son el path y el dominio, es decir, la ruta o directorio y dominio desde la cual la cookie puede ser recuperada.

Manual de PHP

31

Si especificamos como valor del path "/", cualquier script en el servidor podr recuperar su valor. Si especificamos un directorio, por ejemplo /man/, la cookie solo podr ser recuperada por scripts en ese directorio (o desde sus subdirectorios). Y si usamos /man/php/, solo desde ese subdirectorio. Sobre el path ha de tenerse en cuenta que iexplorer y netscape proporcionan distintos valores por defecto si no damos un valor expreso con setcookie. Iexplorer proporciona un valor "/", mientras que netscape suple la omisin indicando directorio y subdirectorio. Mediante el quinto parmetro, dominio, podemos limitar el acceso a los subdominios que tengamos. Por ejemplo, si especificamos "ignside.net", la cookie podr ser recuperada tanto desde http://ignside.net como de www.ignside.net o dev.ignside.net. El ltimo parmetro seguro establece que la cookie solo puede ser mandada si existe una conexin segura (https) Este parmetro se indica mediante un 1 (seguro=true) o un 0 (secure=false) <?php setcookie("visitas", "7", time() + 86400, "", "",1); ?> Aadir que la funcin setcookie devuelve un 1 o un 0 segn se haya ejecutado con xito, aunque que la funcin se haya ejecutado correctamente no implica que la cookie haya sido aceptada por el navegador del usuario. Esto solo puedes comprobarlo leyendo la cookie.

Leyendo cookies
No puedes recuperar (leer) la cookie colocada al visitante hasta que no recarga la pgina. Las cookies son recuperadas automticamente por el script cada vez que se carga una pgina (son enviadas como cabeceras http por el server). Desde la versin 4.1 de PHP podemos recuperar las cookies con $_COOKIE['nombre_cookie']. Se trata de un array autoglobal, accesible desde cualquier parte del script. Este es el mtodo recomendado. Por ejemplo: <?php echo $_COOKIE['saludo']; ?> Tambin podemos recuperar las cookies con $HTTP_COOKIE_VARS que, a diferencia del anterior, no es autoglobal. $HTTP_COOKIE_VARS y $_COOKIE son variables diferentes. Por ltimo, si tenemos PHP configurado con register_globals on, se crean tambin variables individuales (en nuestro ejemplo, $saludo). Este ltimo mtodo es desaconsejado. Para borrar usualmente basta con colocar otra con su mismo nombre sin ningn parmetro ms, por ejemplo: <?php setcookie ("saludo"); //borra la cookie saludo ?> Pero este sistema a veces falla (por ejemplo algunos navegadores no borran la cookie si no coincide el path). Por ello la forma ms segura de borrar una cookie es colocar otra nueva, con el mismo nombre, sin valor, mismo path y nombre de dominio (si se especificaron) y con un tiempo de vida negativo, por ejemplo time() - 3600. Con php 3 las cookies se mandaban al servidor en sentido inverso, as que si deseabas borrar una cookie y colocar otra con el mismo nombre, primero debas crear la cookie y luego borrarla. PHP 4 maneja el orden de las cookies en el orden correcto: primero deber borrar la cookie vieja y luego crear la nueva. Finalmente si quieres acceder inmediatamente a la cookie, puedes recargar la pgina antes de enviarla al usuario, as: <?php if(!isset($COOKIE_SET)) // $cookie_set es nuestra variable de control // de flujo { setcookie("saludo", "hola"); header("Location: $PHP_SELF?COOKIE_SET=1"); // ponemos cookie_set exit; // como true } // Podramos haber redireccionado a otra pgina ?>

Manual de PHP Ejemplo de Cookie

32

En este ejemplo vamos a ver cmo establecer una cookie y cmo se recupera el valor establecido. Para ello pediremos al usuario que introduzca su nombre, que guardaremos en una cookie. Primero pedimos al usuario que introduzca el valor de su nombre, usamos un formulario que procesar la pgina procesarcookie.php. nombrarcookie.php <html> <head> <title> Procesar Cookie </title> </head> <body> <H1>Ejemplo de uso de cookie</H1> Introduzca su nombre: <form action="procesarcookie.php" method="get"> <input type="text" name="nombre"><br> <input type="submit" value="Enviar"> </form> </body> </html> Se establece la cookie ejemusuario con el valor introducido anteriormente, y cuya duracin es una hora. procesarcookie.php <?php setcookie("ejemusuario", $_GET['nombre'], time()+3600,"/",""); ?> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de uso de cookie</H1> Se ha establecido una cookie de nombre <b>ejemusuario</b> con el valor: <b><? print $_GET['nombre']; ?></b> que ser vlida durante 1 hora. </body> </html> En este ejemplo vemos lo fcil que es recuperar el valor de la cookie establecida anteriormente. <html> <head> <title>Procesar Cookie</title> </head> <body> <H1>Ejemplo de uso de cookie</H1> Se ha establecido la cookie de nombre <b>ejemusuario</b> vale: <b><? print $_COOKIE['ejemusuario']; ?></b> </body> </html>

You might also like