Académique Documents
Professionnel Documents
Culture Documents
Primeros pasos
- Condicionales - Bucles - Salida - Cadenas Funciones y librerias - Funciones - Libreras Ejemplos prcticos - Formateo de pgina - Enlace externo
Procesado de formularios
- Crear la base de datos - Conectarse a la BD - Consultas a la BD - Insercin de registros - Borrado de registros Seguridad
Conceptos bsicos
El lenguaje PHP 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 mas 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 pagina 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.
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo 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 PHP.
No importa si no entiende muy bien el programa este ejemplo solo es para ilustrar como se intercala el cdigo HTML y el cdigo
Pgina 1 de 26
Variables
Una variable es un contenedor de informacin, en el que podemos meter nmeros enteros, nmeros decimales, carcteres... el contenido de las variables se puede leer y se puede cambiar durante la ejecucin de una pgina PHP. En PHP todas las variables comienzan con el smbolo del dlar
tienen tipos, es decir que una misma variable puede contener un nmero y luego puede contener carcteres.
<!-- Manual de PHP de WebEstilo.com --> <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, 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
$a, $b y $c y con la instruccin echo hemos impreso el valor que contenan, global
nombre_variable;
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 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.
5 + 6 7 - 9 6 * 3 4 / 8 7 % 2 $a++ $a--
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</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++;
Pgina 2 de 26
Comparacin
Los operadores de comparacin son usados para comparar valores y as poder tomar decisiones. Operador == != < > <= >= Nombre Igual Distinto Menor que Mayor que Menor o igual Mayor o igual Ejemplo Devuelve cierto cuando:
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</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>
Lgicos
Los operadores lgicos son usados para evaluar varias comparaciones, combinando los posibles valores de estas. Operador && and || or ! Nombre Y Y O O No Ejemplo Devuelve cierto cuando: Devuelve verdadero cuando ambas condiciones son verdaderas. Devuelve verdadero cuando ambas condiciones son verdaderas. 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.
(7>2) && (2<4) (7>2) and (2<4) (7>2) || (2<4) (7>2) or (2<4) ! (7>2)
Pgina 3 de 26
8; 3; 3; ($a == $b) && ($c > $b),"<br>"; ($a == $b) || ($b == $c),"<br>"; !($b <= $c),"<br>";
Condicionales
Las sentencias condicionales nos permiten ejecutar o no unas ciertas instrucciones dependiendo del resultado de evaluar una condicin. Las ms frecuentes son la instruccin Sentencia
if y la instruccin switch.
if ... else
<?php if (condicin) { Sentencias a ejecutar cuando la condicin es cierta. } else { Sentecias 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
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</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 Sentencia
else.
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <?php
Pgina 4 de 26
$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 echo "La variable contiene otro valor"; echo " distinto de arriba y abajo"; } ?> </body> </html>
Con la sentencia anterior, dependiendo del valor de la variable
switch podemos ejecutar unas u otras instrucciones dependiendo del valor de una variable, en el ejemplo $posicion se ejecuta el bloque 1 cuando el valor es "arriba", el bloque 2 cuando el
Bucles
Los bucles nos permiten iterar conjuntos de instrucciones, es decir repetir la ejecucin de un conjunto de instrucciones mientras se cumpla una condicin. Sentencia
while
while.
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> Inicio<BR> <?php $i=0; while ($i<10) { echo "El valor de i es ", $i,"<br>"; $i++; } ?> Final<BR> </body> </html>
En el siguiente ejemplo, el valor de manera que cuando Sentencia
$i al comienzo es 0, durante la ejecucin del bucle, se va sumando 1 al valor de $i de $i vale 10 ya no se cumple la condicin y se termina la ejecucin del bucle.
for
Pgina 5 de 26
} ?> <!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> Inicio<BR> <?php for($i=0 ; $i<10 ; $i++) { echo "El valor de i es ", $i,"<br>"; } ?> Final<BR> </body> </html>
La instruccin del bucle. El primer parmetro del
for es la instruccin de bucles ms completa. En una sola instruccin nos permite controlar todo el funcionamiento 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. Puede consultar cualquier duda en el foro de discusin.
Recorrer un array utilizando foreach en vez de un blucle for: <? /* Creo un array */ $las_vocales = array ('a','e','i','o','u'); /* Recorro el array utilizando foreach */ foreach ($las_vocales as $elem) { print $elem.'<br>'; } print '<br>'; /* Es equivalente a realizar */ for ($i=0;$i<count($las_vocales);$i++) { print $las_vocales[$i].'<br>'; } ?>
Salida
Hasta ahora hemos usado la instruccin Sentencia permite formatear la salida. En esta pgina veremos la instruccin
echo para realizar salida a pantalla, esta instruccin es bastante limitada ya que no nos printf que nos da mucha ms potencia.
printf
Pgina 6 de 26
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.
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</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 carcteres especiales que indican como formatear las variables que se incluyen en la instruccin. Elemento %s %d %f %c Tipo de variable Cadena de carcteres. Nmero sin decimales. Nmero con decimales. Carcter ASCII.
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <?php $var="texto"; $num=3; printf("Puede fcimente intercalar <b>%s</b> con nmeros <b>%d</b> <br>",$var,$num); printf("<TABLE BORDER=1 CELLPADDING=20>"); for ($i=0;$i<10;$i++) { printf("<tr><td>%10.d</td></tr>",$i); } 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. 1. 2. 3. 4. 5. 6. 7.
strlen(cadena). Nos devuelve el nmero de carcteres 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.
Pgina 7 de 26
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</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; instruccin3; instruccin4; 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
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <?php function media_aritmetica($a, $b) { $media=($a+$b)/2; return $media; }
Pgina 8 de 26
Librera
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.
<!-- Manual de PHP de WebEstilo.com --> <?php function CabeceraPagina() { ?> <FONT SIZE="+1">Esta cabecera estar en todas sus pginas.</FONT><BR> <hr> <? } function PiePagina() { ?> <hr> <FONT SIZE="-1">Este es el pie de pgina.</FONT><BR> Autor: Joaquin Gracia <? } ?>
Ahora vamos a crear 2 pginas que usan la librera definida anteriormente para conseguir que las dos paginas tengan la misma cabecera y pie de pagina. La instruccin para incluir una librera en nuestra pgina es
include("nombre de librera")
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <?php include("libreria01.phtml") ?> <?php CabeceraPagina(); ?> Pgina 1 <BR><BR><BR><BR><BR> Contenido blalbl blalb alb<BR><BR> ms cosas...<BR><BR> fin<BR><BR> <?php PiePagina(); ?> </body> </html> <!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title>
Pgina 9 de 26
</head> <body> <?php include("libreria01.phtml") ?> <?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>
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de procesado de formularios</H1> Introduzca su nombre: <FORM ACTION="procesa.phtml" 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 etiqueta
ACTION de la
FORM. FORM, esta variable creada tena el mismo nombre $_POST[] o $_GET[] dependiendo del mtodo usado
En versiones anteriores a 4.2.0 PHP creaba una variable por cada elemento del acceder a las variables del formulario hay que usar el array de parmetros para enviar los parmetros. En este ejemplo se ha creado una entrada en el array navegante.
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
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de procesado de formularios</H1> El nombre que ha introducido es: <?php echo $_GET['nombre'] ?> <br> </body> </html>
Pgina 10 de 26
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de procesado de formularios</H1> <FORM ACTION="procesa2.phtml" 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> <!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de procesado de formularios</H1> <FORM ACTION="procesa2.phtml" 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.phtml
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</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>
El resultado final es el mismo, solo que con el mtodo GET podemos ver los parmetros pasados ya que estn codificados en la URL.
Envio 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); ?>
tema o subject del mensaje y el parmetro
destinatario pondremos la direccin de email a donde se enviar el mensaje, en el parmetro tema el 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.
En el parmetro
<?php mail(destinatario, tema, texto del mensaje, informacin adicional de cabecera); ?>
En la informacin de cabecera podremos incluir parmetros adicionales al mensaje como
Pgina 11 de 26
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de envio de email</H1> Introduzca su direccion de email: <FORM ACTION="email.phtml" 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.phtml
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de envio de email</H1> <? $direccion=$_GET['direccion']; $tipo=$_GET['tipo']; if ($direccion!=""){ if ($tipo=="plano"){ // Envio en formato texto plano mail($direccion,"Ejemplo de envio de email","Ejemplo de envio de email de texto plano\n\nWebEstilo.\nhttp://www.webestilo.com/\n Manuales para desarrolladores web.\n","FROM: Pruebas <webmaster@hotmail.com>\n"); } else { // Envio en formato HTML mail($direccion,"Ejemplo de envio de email","<html><head><title>WebEstilo. Manual de PHP</title></head><body>Ejemplo de envio de email de HTML<br><br>WebEstilo.<br>http://www.webestilo.com/<br> <u>Manuales</u> para <b>desarrolladores</b> web.</body></html>","Content-type: text/html\n", "FROM: Pruebas <webmaster@hotmail.com>\n"); } echo "Se ha enviado un email a la direccion: ",$direccion," en formato <b>",$tipo,"</b>."; } ?> <br> </FORM> </body> </html>
Pgina 12 de 26
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. En este ejemplo creamos una tabla llamada prueba con 3 campos: un campo identificador, que nos servir para identificar unvocamente una fila con el valor de dicho campo, otro campo con el nombre de una persona y por ltimo un campo con el apellido de la persona. 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 con la siguiente instruccin:
CREATE TABLE prueba ( ID_Prueba int(11) DEFAULT '0' NOT NULL auto_increment, Nombre varchar(100), Apellidos varchar(100), PRIMARY KEY (ID_Prueba), UNIQUE ID_Prueba (ID_Prueba) );
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <?php function Conectarse() { if (!($link=mysql_connect("localhost","usuario","Password"))) { echo "Error conectando a la base de datos."; exit(); } if (!mysql_select_db("base_datos",$link)) { echo "Error seleccionando la base de datos."; exit(); } return $link; } $link=Conectarse(); echo "Conexin con la base de datos conseguida.<br>"; mysql_close($link); //cierra la conexion ?> </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
Pgina 13 de 26
<html> <head> <title>Title here!</title> </head> <body> <?php #Esta es una forma mucho mas facil de #conectarse a la base de datos en MySql #coneccion con el MDB en MySql $link = mysql_connect("NombreHost","Usuario","contrasea") or die ("no se ha podido conectar"); #Seleccion de la base de datos a utilizar mysql_select_db("dbprueba") or die("Error al tratar de selecccionar esta base"); #cierra la base de datos mysql_close($link); ?> </body> </html>
<!-- Manual de PHP de WebEstilo.com --> <?php function Conectarse() { if (!($link=mysql_connect("localhost","usuario","Password"))) { echo "Error conectando a la base de datos."; exit(); } if (!mysql_select_db("base_datos",$link)) { echo "Error seleccionando la base de datos."; exit(); } return $link; } ?> <!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de uso de bases de datos con PHP y MySQL</H1> <?php include("conex.phtml"); $link=Conectarse();
Pgina 14 de 26
$result=mysql_query("select * from prueba",$link); ?> <TABLE BORDER=1 CELLSPACING=1 CELLPADDING=1> <TR><TD> Nombre</TD><TD> Apellidos </TD></TR> <?php while($row = mysql_fetch_array($result)) { printf("<tr><td> %s</td><td> %s </td></tr>", $row["Nombre"],$row["Apellidos"]); } mysql_free_result($result); mysql_close($link); ?> </table> </body> </html>
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. Aportaciones de usuarios Claudio Marrero (yagoloco22@hotmail.com)
29/08/2003
en realidad es mejor crear algo como esto: search.php: <? /* * search.php * * Script for searching a database populated with keywords by the * populate.php-script. */ print "<html><head><title>My Search Engine</title></head><body>\n"; if( $_POST['keyword'] ) { /* Connect to the database: */ mysql_pconnect("localhost","construyasl","lzdttV6u0MoC") or die("ERROR: Could not connect to database!"); mysql_select_db("construyasl"); /* Get timestamp before executing the query: */ $start_time = getmicrotime(); /* Set $keyword and $results, and use addslashes() to * minimize the risk of executing unwanted SQL commands: */ $keyword = addslashes( $_POST['keyword'] ); $results = addslashes( $_POST['results'] ); /* Execute the query that performs the actual search in the DB: */ $result = mysql_query(" SELECT p.page_url AS url, COUNT(*) AS occurrences FROM page p, word w, occurrence o WHERE p.page_id = o.page_id AND w.word_id = o.word_id AND w.word_word = \"$keyword\" GROUP BY p.page_id ORDER BY occurrences DESC
Pgina 15 de 26
LIMIT $results" ); /* Get timestamp when the query is finished: */ $end_time = getmicrotime(); /* Present the search-results: */ print "<h2>Search results for '".$_POST['keyword']."':</h2>\n"; for( $i = 1; $row = mysql_fetch_array($result); $i++ ) { print "$i. <a href='".$row['url']."'>".$row['url']."</a>\n"; print "(occurrences: ".$row['occurrences'].")<br><br>\n"; } /* Present how long it took the execute the query: */ print "query executed in ".(substr($end_time-$start_time,0,5))." seconds."; } else { /* If no keyword is defined, present the search page instead: */ print "<form method='post'> Keyword: <input type='text' size='20' name='keyword'>\n"; print "Results: <select name='results'><option value='5'>5</option>\n"; print "<option value='10'>10</option><option value='15'>15</option>\n"; print "<option value='20'>20</option></select>\n"; print "<input type='submit' value='Search'></form>\n"; } print "</body></html>\n"; /* Simple function for retrieving the current timestamp in microseconds: */ function getmicrotime() { list($usec, $sec) = explode(" ",microtime()); return ((float)$usec + (float)$sec); } ?> Y el otro es populate.php:
<? /* * populate.php * * Script for populating the search database with words, * pages and word-occurences. */ /* Connect to the database: */ mysql_pconnect("localhost","root","secret") or die("ERROR: Could not connect to database!"); mysql_select_db("test"); /* Define the URL that should be processed: */ $url = addslashes( $_GET['url'] ); if( !$url )
Pgina 16 de 26
{ die( "You need to define a URL to process." ); } else if( substr($url,0,7) != "http://" ) { $url = "http://$url"; } /* Does this URL already have a record in the page-table? */ $result = mysql_query("SELECT page_id FROM page WHERE page_url = \"$url\""); $row = mysql_fetch_array($result); if( $row['page_id'] ) { /* If yes, use the old page_id: */ $page_id = $row['page_id']; } else { /* If not, create one: */ mysql_query("INSERT INTO page (page_url) VALUES (\"$url\")"); $page_id = mysql_insert_id(); } /* Start parsing through the text, and build an index in the database: */ if( !($fd = fopen($url,"r")) ) die( "Could not open URL!" ); while( $buf = fgets($fd,1024) ) { /* Remove whitespace from beginning and end of string: */ $buf = trim($buf); /* Try to remove all HTML-tags: */ $buf = strip_tags($buf); $buf = ereg_replace('/&\w;/', '', $buf); /* Extract all words matching the regexp from the current line: */ preg_match_all("/(\b[\w+]+\b)/",$buf,$words); /* Loop through all words/occurrences and insert them into the database: */ for( $i = 0; $words[$i]; $i++ ) { for( $j = 0; $words[$i][$j]; $j++ ) { /* Does the current word already have a record in the word-table? */ $cur_word = addslashes( strtolower($words[$i][$j]) ); $result = mysql_query("SELECT word_id FROM word WHERE word_word = '$cur_word'"); $row = mysql_fetch_array($result); if( $row['word_id'] ) { /* If yes, use the old word_id: */ $word_id = $row['word_id']; } else { /* If not, create one: */ mysql_query("INSERT INTO word (word_word) VALUES (\"$cur_word\")"); $word_id = mysql_insert_id();
Pgina 17 de 26
} /* And finally, register the occurrence of the word: */ mysql_query("INSERT INTO occurrence (word_id,page_id) VALUES ($word_id,$page_id)"); print "Indexing: $cur_word<br>"; } } } fclose($fd); ?>
Insercin de 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
ser procesado una pagina PHP, esta pgina lo que har ser introducir los datos del formulario en la base de datos. ejem07d.phtml
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de uso de bases de datos con PHP y MySQL</H1> <FORM ACTION="procesar.phtml"> <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> </TABLE> <INPUT TYPE="submit" NAME="accion" VALUE="Grabar"> </FORM> <hr> <?php include("conex.phtml"); $link=Conectarse(); $result=mysql_query("select * from prueba",$link); ?> <TABLE BORDER=1 CELLSPACING=1 CELLPADDING=1> <TR><TD> <B>Nombre</B></TD> <TD> <B>Apellidos</B> </TD></TR> <?php while($row = mysql_fetch_array($result)) { printf("<tr><td> %s</td> <td> %s </td></tr>", $row["Nombre"], $row["Apellidos"]); } mysql_free_result($result); mysql_close($link); ?> </table> </body> </html>
Pgina 18 de 26
procesar.phtml
<?php include("conex.phtml"); $link=Conectarse(); $nombre=$_GET['nombre']; $apellidos=$_GET['apellidos']; mysql_query("insert into prueba (Nombre,Apellidos) values ('$nombre','$apellidos')",$link); header("Location: ejem07d.phtml"); ?>
La primera pgina PHP
ejem07d.phtml es un formulario que nos permite introducir nombre y apellido 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 pagina
procesar.phtml que aadir los datos a la tabla. La segunda pgina procesar.phtml se conecta a la base de datos y aade un nuevo registro con la instruccin insert del lenguaje de base de datos SQL. Una vez el registro se ha aadido se vuelve a cargar la pgina ejem07d.phtml
Borrado de 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 cada registro, de esta manera la pgina ejem07e.phtml
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de uso de bases de datos con PHP y MySQL</H1> <?php include("conex.phtml"); $link=Conectarse(); $result=mysql_query("select * from prueba",$link); ?> <TABLE BORDER=1 CELLSPACING=1 CELLPADDING=1> <TR><TD> <B>Nombre</B></TD> <TD> <B>Apellidos</B> </TD> <TD> <B>Borrar</B> </TD></TR> <?php while($row = mysql_fetch_array($result)) { printf("<tr><td> %s</td><td> %s </td><td><a href=\"borra.phtml?id=%d\">Borra</a></td></tr>", $row["Nombre"],$row["Apellidos"],$row["ID_Prueba"]); } mysql_free_result($result); mysql_close($link); ?> </table> </body> </html>
borra.phtml
<?php include("conex.phtml"); $link=Conectarse(); $id=$_GET['id']; mysql_query("delete from prueba where ID_Prueba = $id",$link);
Pgina 19 de 26
borra.phtml se conecta a la base de datos y borra el registro indicado en la variable $id que ha sido pasado ejem07e.phtml. Una vez el registro se ha borrado se vuelve a cargar la pgina ejem07e.phtml
Restringir el acceso
En esta seccin vamos a explicar cmo podemos restringir el acceso a segn qu pginas, para que solo 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 solo 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 1. 2. cabecera:
Para que el navegador nos muestre la ventana de peticin de nombre de usuario y contrasea basta con enviar la siguiente
<?php // Manual de PHP de WebEstilo.com if (!isset($PHP_AUTH_USER)) { header('WWW-Authenticate: Basic realm="Acceso restringido"'); header('HTTP/1.0 401 Unauthorized'); echo 'Authorization Required.'; 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 tendremos acceso al resto de la pgina.
<?php // Manual de PHP de WebEstilo.com if (($PHP_AUTH_USER!="Joe") || ($PHP_AUTH_PW!="123")) { header('WWW-Authenticate: Basic realm="Acceso restringido"'); header('HTTP/1.0 401 Unauthorized'); echo 'Authorization Required.'; exit; } ?> <!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</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.
Pgina 20 de 26
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: passwords.txt
<?php // Manual de PHP de WebEstilo.com if (!isset($PHP_AUTH_USER)) { header('WWW-Authenticate: Basic realm="Acceso restringido"'); header('HTTP/1.0 401 Unauthorized'); echo 'Authorization Required.'; 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 Unauthorized'); echo 'Authorization Required.'; exit; } ?> <!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> Ha conseguido el acceso a la <B>zona restringida</B> con el usuario <?php echo $PHP_AUTH_USER?>. </body> </html>
Pgina 21 de 26
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. Por lo tanto lo comentado a partir de aqu es solo aplicable a PHP4. Si an desarrollas PHP3, tendrs que crear tus propias libreras de gestin de sesiones o recurrir a alguna de las existentes, como la de PHPLIB .
Inicializacin de la sesin
Por: Jose Valle Para utilizar sesiones en PHP lo primero es inicializarlas. Podemos hacerlo explcitamente, mediante la funcin
<?php // Manual de PHP de WebEstilo.com 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 ver si la sesin est disponible:
<?php // Manual de PHP de WebEstilo.com 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()
Ejemplo prctico
Por: Jose Valle Veamos otro ejemplo que, tal vez, te lo aclare un poco ms:
<?php // Manual de PHP de WebEstilo.com session_register('contador'); echo '<a href="'.$PHP_SELF.'?'.$SID.'">Contador vale: '.++$_SESSION['contador']. '</a>'; ?>
Como dije anteriormente la sesin se crea o recoge mediante 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.
$contador en la primera lnea del script. En la segunda lnea, entre otras $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
En nuestro ejemplo anterior, registramos la variable cosas, cada vez que recarguemos la pgina o hagamos click sobre el enlace, el valor de prctica:
<?php // Manual de PHP de WebEstilo.com 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().
Aportaciones de usuarios German Pizarro (german.pizarro@alumnos.utfsm.c)
08/08/2003
Pgina 22 de 26
Para ser ms genrico debiera considerarse que al deshabilitar register_globals no puede usarse los nombres de las variables slo como $variable, sino como $_POST[variable]. so!+
Alfonso (lacielsa290@hotmail.com)
27/03/2004
$_REQUEST[$misesion] en el ejemplo en lugar de simplemente $misesion en el caso de tener deshabilitado Global en el php.ini .... Saludos..
Error comn
Por: Jose Valle 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 Si tienes los cookies activados, te encontrars un error de este tipo:
<?php.
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 compra
Por: Jose Valle 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:
<?php // Manual de PHP de WebEstilo.com 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; } } $_SESSION['itemsEnCesta']=$itemsEnCesta; ?> <html> <body> <tt> <form action="<?=$PHP_SELF."?".$SID?>" method="post"> Dime el producto <input type="text" name="item" size="20"><br> Cuantas unidades <input type="text" name="cantidad" size="20"><br>
Pgina 23 de 26
<input type="submit" value="Aadir a la cesta"><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>
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
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.
Funcionamiento
La cookie es enviada al navegador desde el servidor y si este la acepta permanece en l.
El navegador las enva, permitiendo la identificacin del usuario por parte del servidor.
A continuacin vamos a ver como usar las cookies para nuestro beneficio.
Pgina 24 de 26
int setcookie (string Nombre [, string Valor [, int Expire [, string Path [, string Dominio [, int Secure]]]]])
Setcookie() define una cookie que es enviada junto con el resto de la informacin de la cabecera(header). Las cookies deben <HTML> o <HEAD>. Esta es una restriccin de las cookies no de PHP.
ser enviadas antes de cualquier tag de html, por lo tanto deberemos realizar la llamada a estas funciones antes de cualquier tag Todos los argumentos excepto el nombre son opcionales.
Ejemplo
Nombre. Nombre de la cookie. Si creamos una cookie solamente con el nombre, en el cliente se eliminara la cookie que exista
con ese nombre. Tambin podemos reemplazar cualquier argumento con una cadena vaca ("").
Value. Valor que almacenar la cookie en el cliente. Expire. El argumento expire es un argumento entero que indica la hora en que se eliminara la cookie en el formato de hora que devuelven las funciones UNIX time() y mktime(). Normalmente se usa time() + N. segundos de duracin, para especificar la duracin de una cookie. Path. Subdirectorio en donde tiene valor la cookie. Dominio. Dominio en donde tiene valor la cookie. Si ponemos como dominio www.domain.com la cookie no se transmite para domain.com, mientras que si ponemos domain.com la cookie se transmite tanto para domain.com como para www.domain.com Secure. El argumento secure indica que la cookie solo se transmitir a travs de una conexin segura HTTPS. usuario que contiene el valor Luis, que dura 1 hora (3600 webestilo.com
procesar_cookie.phtml.
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</title> </head> <body> <H1>Ejemplo de uso de cookie</H1> Introduzca su nombre: <FORM ACTION="procesar_cookie.phtml" METHOD="GET"> <INPUT TYPE="text" NAME="nombre"><BR> <INPUT TYPE="submit" VALUE="Enviar"> </FORM> </body> </html>
Se establece la cookie
<?php // Manual de PHP de WebEstilo.com 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.
Pgina 25 de 26
<!-- Manual de PHP de WebEstilo.com --> <html> <head> <title>Ejemplo de PHP</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>
Pgina 26 de 26