Documente Academic
Documente Profesional
Documente Cultură
Curso PHP
29. Clusula Group By de SQL.
30. Parmetros en un hipervnculo.
31. Paginacin de registros.
32. Subir un archivo al servidor (Upload)
33. Creacin y lectura de una cookie
34. Borrado de una cookie
35. Cookie de sesin
36. Variables de sesin ($_SESSION)
37. Incluir un archivo externo (require_once)
38. Redireccionar a otra pgina (header)
39. Creacin de imgenes dinmicas desde PHP.
40. Agregar imgenes dinmicas en un archivo HTML
41. Administracin de fechas y horas (funcin date)
42. Validacin de una fecha ingresada por teclado (checkdate)
43. Carga de una fecha en una tabla de MySQL
44. Formateo de datos en una pgina (printf)
45. Formateo de datos y salida a un string (sprintf)
Curso PHP
1. Que es PHP?
PHP (acrnimo de "PHP: Hypertext Preprocessor") es un lenguaje interpretado de alto nivel
embebido en pginas HTML y ejecutado en el servidor.
Hay que entender primero como funciona la solicitud de pginas en un navegador para
comenzar a programar en PHP.
Comunicacin entre el cliente y el servidor sin PHP:
1 - Tipiamos en la barra del navegador la direccin y el archivo a solicitar.
2 - El web browser (navegador) enva el mensaje a travs de Internet a la computadora, por
ejemplo www.lanacion.com/pagina1.htm solicitando la pgina (archivo) pagina1.htm
3 - El web server (servidor web, que puede ser el Apache, IIS, etc.) que es un programa que
se ejecuta en la mquina www.lanacion.com, recibe el mensaje y lee el archivo solicitado
desde el disco duro.
4 - El servidor web enva el archivo solicitado por el navegador tal cual est en el disco duro.
5 - El navegador muestra en pantalla el archivo que envi el servidor web.
Este proceso siempre es el mismo cuando hablamos de pginas estticas (pginas que no
cambian), cualquiera sea el cliente que solicita la pgina el contenido siempre ser el mismo.
La nica forma que el contenido del archivo cambie es que el administrador de ese sitio web
edite el contenido del archivo pagina1.htm y haga modificaciones.
Comunicacin entre el cliente y el servidor con PHP:
1 - Tipeamos en la barra del navegador la direccin y el archivo a solicitar.
2 - El web browser (navegador) enva el mensaje a travs de Internet a la computadora
llamada www.lanacion.com solicitando la pgina (archivo) pagina1.php
3 - El web server (servidor web, que puede ser el Apache, IIS, etc.), recibe el mensaje y al
ver que la extension es "php" solicita al interprete de PHP (que es otro programa que se
ejecuta en el servidor web) que le enve el archivo.
4 - El intrprete PHP lee desde el disco el archivo pagina1.php
5 - El intrprete PHP ejecuta los comandos contenidos en el archivo y eventualmente se
comunica con un gestor de base de datos (ejemplos de ellos pueden ser MySql, Oracle,
Informix, SQL Server, etc.)
6 - Luego de ejecutar el programa contenido en el archivo enva ste al servidor web.
7 - El servidor web enva la pgina al cliente que la haba solicitado.
8 - El navegador muestra en pantalla el archivo que envi el servidor web.
Para aquellas personas que conocen otros lenguajes de programacin (C - Java - C# - Pascal
etc.) la salida de los resultados normalmente es la pantalla, en PHP la salida es la pgina
HTML (luego sta viaja por internet y llega al cliente que la solicit)
Curso PHP
Curso PHP
Curso PHP
Problema a resolver
Sabiendo que la funcin rand nos retorna un valor aleatorio entre un rango de dos enteros:
$num=rand(1,100);
En la variable $num se almacena un valor entero que la computadora genera en forma
aleatoria entre 1 y 100.
Hacer un programa que lo muestre por pantalla al valor generado. Mostrar adems si es
menor o igual a 50 o si es mayor.
Para imprimir el contenido de una variable tambin utilizamos el comando echo:
echo $num;
Curso PHP
4. Tipos de variables
Los nombres de variables comienzan con el signo $ y son sensibles a maysculas y minsculas
(no as las palabras claves del lenguaje).
En PHP no es necesario definir el tipo antes de utilizarla, las mismas se crean en el momento
de emplearlas. Las variables se declaran cuando se le asigna un valor, por ejemplo:
$dia = 24; //Se declara una variable de tipo integer.
$sueldo = 758.43; //Se declara una variable de tipo double.
$nombre = "juan"; //Se declara una variable de tipo string.
$exite = true; //Se declara una variable boolean.
Tambin podemos hacer notar que para disponer comentarios de lnea debemos utilizar dos
caracteres //
Para la impresin de variables utilizaremos inicialmente el comando echo. Un programa
completo que inicializa y muestra el contenido de cuatro variables de distinto tipo es:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$dia = 24; //Se declara una variable de tipo integer.
$sueldo = 758.43; //Se declara una variable de tipo double.
$nombre = "juan"; //Se declara una variable de tipo string.
$exite = true; //Se declara una variable boolean.
echo "Variable entera:";
echo $dia;
echo "<br>";
echo "Variable double:";
echo $sueldo;
echo "<br>";
echo "Variable string:";
echo $nombre;
echo "<br>";
echo "Variable boolean:";
echo $exite;
?>
</body>
</html>
Hemos utilizado un comando echo para mostrar los mensajes, otro el contenido de variables y
finalmente otro para imprimir marcas HTML. Este proceso puede acortarse un poco pero para
que sea ms claro inicialmente tomaremos el camino largo de hacer la impresin de un dato
con cada comando echo.
Problema a resolver
Definir una variable de cada tipo: integer, double, string y boolean. Luego imprimirlas en la
pgina, una por lnea
Curso PHP
Curso PHP
Curso PHP
Instruccin Z;
}
Para las condiciones tener en cuenta que disponemos de los siguientes operadores:
== para ver si una variable es igual a otra.
!= distinto.
>= mayor o igual.
> mayor.
<= menor o igual
< menor
La mejor forma de entender esta estructura condicional es por medio de ejemplos. El primero
que nos plantearemos es generar un valor aleatorio (es decir lo elige la mquina al azar,
como extraer una bolilla de un bolillero de lotera) comprendido entre 1 y 10. Luego
mostraremos un mensaje si es menor o igual a 5 o si es mayor a 5.
El programa completo es:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$valor=rand(1,10);
echo "El valor sorteado es $valor<br>";
if ($valor<=5)
{
echo "Es menor o igual a 5";
}
else
{
echo "Es mayor a 5";
}
?>
</body>
</html>
10
Curso PHP
identificar que para que tenga un dgito debe generarse un valor entre 1 y 9, para que tenga
dos dgitos deber estar comprendido entre 10 y 90, y finalmente para tener 3 dgitos deber
ser el valor 100.
La pgina con el programa respectivo es:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$valor=rand(1,100);
echo "El valor sorteado es $valor<br>";
if ($valor<=9)
{
echo "Tiene un dgito";
}
else
{
if ($valor<100)
{
echo "Tiene 2 dgitos";
}
else
{
echo "Tiene 3 dgitos";
}
}
?>
</body>
</html>
Es importante notar como la segunda estructura if se encuentra contenida entre las llaves del
else del primer if. Es decir que si el valor aleatorio es menor o igual a 9 se ejecuta el bloque
del verdadero del primer if y no se ejecuta por lo tanto el if anidado en el else. Por el
contrario si la condicin del primer if se verifica false se ejecuta el bloque del else del primer
if, la misma contiene una estructura if con sus bloques del verdadero y false.
A modo ilustrativo el mismo ejemplo resuelto con la estructura if/elseif ser:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$valor=100;//rand(1,100);
echo "El valor sorteado es $valor<br>";
if ($valor<=9)
{
echo "Tiene un dgito";
}
elseif ($valor<100)
{
echo "Tiene 2 dgitos";
}
else
{
echo "Tiene 3 dgitos";
}
?>
11
Curso PHP
</body>
</html>
Si uno tiene mucha prctica con otros lenguajes de programacin esta estructura de if
anidados le ser mas adecuada, en caso que haya empezado a programar hace poco ser
conveniente que elija y practique la primera forma.
Problema a resolver
Generar un valor aleatorio entre 1 y 5. Luego imprimir en castellano el nmero (Ej. si se
genera el 3 luego mostrar en la pgina el string "tres").
Para ver si una variable es igual a cierto valor debemos plantear una condicin similar a:
if ($valor==3)
{
//algoritmo
}
12
Curso PHP
13
Curso PHP
</head>
<body>
<?php
$valor=rand(1,100);
$inicio=1;
while($inicio<=$valor)
{
echo $inicio;
echo "<br>";
$inicio++;
}
?>
</body>
</html>
La variable $inicio tiene el valor 1 antes de ingresar al while. Cada vez que se ejecuta una vez
el bloque del while se incrementa $inicio en uno. Cuando $inicio supere la variable aleatoria
$valor finalizar la estructura repetitiva y pasar a ejecutarse la instruccin inmediatamente
siguiente a la llave de cerrado.
Es importante notar que luego de la condicin del while NO disponemos PUNTO y COMA.
Por ltimo tenemos en el lenguaje una estructura repetitiva similar al while llamada
do/while, donde la condicin se verifica luego de ejecutarse el bloque repetitivo.
do
{
[Instrucciones];
} while (condicin);
Queda como tarea intentar hacer una pgina empleando esta estructura. Tener en cuenta que
al final de la lnea del while SI LLEVA punto y coma.
Problema a resolver
Mostrar la tabla de multiplicar del 2. Emplear el for, luego el while y por ltimo el do/while.
La estructura for permite incrementar una variable de 2 en 2:
for($f=2;$f<=20;$f=$f+2)
14
Curso PHP
15
Curso PHP
Problema a resolver
Confeccionar un formulario que solicite la carga de un nombre de persona y su edad, luego
mostrar en otra pgina si es mayor de edad (si la edad es mayor o igual a 18)
16
Curso PHP
17
Curso PHP
$resta=$_REQUEST['valor1'] - $_REQUEST['valor2'];
echo "La resta es:".$resta;
}
}
?>
</body>
</html>
El vector asociativo $_REQUEST tiene tres componentes: $_REQUEST['radio1']
$_REQUEST['valor1'] $_REQUEST['valor2'] En la componente $_REQUEST['radio1']
almacena la cadena "suma" o "resta" segn cual se seleccion en el formulario.
Con dos if verificamos cual operacin est seleccionada y procedemos a efectuarla:
if ($_REQUEST['radio1']=="suma")
{
$suma=$_REQUEST['valor1'] + $_REQUEST['valor2'];
echo "La suma es:".$suma;
.
.
Problema a resolver
Solicitar que se ingrese por teclado el nombre de una persona y disponer tres controles de
tipo radio que nos permitan seleccionar si la persona: 1-no tiene estudios, 2-estudios
primarios, 3-estudios secundarios. En la pgina que procesa el formulario mostrar el nombre
de la persona y un mensaje indicando el tipo de estudios que posee.
18
Curso PHP
19
Curso PHP
Si el checkbox no est seleccionado en el formulario no se crea una entrada en el vector
asociativo $_REQUEST, para saber si existe una determinada componente en un vector se
emplea la funcin isset, si retorna true significa que existe y por lo tanto el checkbox est
seleccionado.
Disponemos dos if a la misma altura ya que los dos controles de tipo checkbox podran estar
seleccionados.
Problema a resolver
Confeccionar un formulario que solicite la carga del nombre de una persona y que permita
seleccionar una serie de deportes que practica (futbol, basket, tennis, voley)
Mostrar en la pgina que procesa el formulario la cantidad de deportes que practica.
20
Curso PHP
21
Curso PHP
}
?>
</body>
</html>
El vector asociativo $_REQUEST almacena en la componente del control select el valor de la
opcin seleccionada.
Con una serie de if verificamos el valor seleccionado:
if ($_REQUEST['operacion']==suma)
...
Slo se puede seleccionar un elemento de un control select (ms adelante veremos como
seleccionar varios elementos en forma simultnea)
Problema a resolver
Confeccionar un formulario que solicite el ingreso del nombre de una persona y un combo de
seleccin (en este ltimo permitir la seleccin de los ingresos anuales de la persona: 11000,1001-3000,>3000)
En la pgina que procesa el formulario mostrar un mensaje si debe pagar impuestos a las
ganancias (si supera 3000).
22
Curso PHP
Problema a resolver
Confeccionar una pgina que muestre un contrato dentro de un textarea, disponer puntos
suspensivos donde el operador debe ingresar un texto. La pgina que procesa el formulario
slo debe mostrar el contrato con las modificaciones que hizo el operador.
Ej. de un contrato puede ser:
En la ciudad de [........], se acuerda entre la Empresa [..........] representada por el Sr.
[..............] en su carcter de Apoderado, con domicilio en la calle [..............] y el Sr.
[..............], futuro empleado con domicilio en [..............], celebrar el presente contrato
a Plazo Fijo, de acuerdo a la normativa vigente de los artculos 90,92,93,94, 95 y
concordantes de la Ley de Contrato de Trabajo N 20.744.
23
Curso PHP
//3
24
Curso PHP
25
Curso PHP
26
Curso PHP
27
Curso PHP
Problema a resolver
Confeccionar un programa que muestre el archivo de pedido de pizzas via internet del punto
anterior. (obligatoriamente dar el nombre del archivo de texto como "datos.txt", esto es para
que no se llene mi disco duro de archivos, es decir de ahora en ms siempre que cree un
archivo de texto debe llamarse datos.txt)
28
Curso PHP
Problema a resolver
Crear un vector asociativo que almacene las claves de acceso de 5 usuarios de un sistema.
Acceder a cada componente por su nombre. Imprimir una componente del vector.
29
Curso PHP
30
Curso PHP
</head>
<body>
<?php
function retornarpromedio($valor1,$valor2)
{
$pro=$valor1/$valor2;
return $pro;
}
$v1=100;
$v2=50;
$p=retornarpromedio($v1,$v2);
echo $p;
?>
</body>
</html>
Cuando una funcin retorna un dato debemos emplear la palabra clave return seguida del
valor que devuelve.
En la llamada a la funcin el valor retornado se almacena generalmente en una variable:
$p=retornarpromedio($v1,$v2);
Si queremos que retorne ms de un dato debemos emplear parmetros por referencia.
Supongamos que necesitamos ahora que una funcin nos retorne el cuadrado y cubo de un
nmero:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
function cuadradocubo($valor,&$cuad,&$cub)
{
$cuad=$valor*$valor;
$cub=$valor*$valor*$valor;
}
cuadradocubo(2,$c1,$c2);
echo "El cuadrado de 2 es:".$c1."<br>";
echo "El cubo de 2 es:".$c2;
?>
</body>
</html>
Es decir, cuando le antecedemos el caractr ampersand al parmetro, es por referencia. El
objetivo es asignarle cierto valor al parmetro y posteriormente el dato quedar almacenado
en la variable que le pasamos a la funcin.
function cuadradocubo($valor,&$cuad,&$cub)
{
$cuad=$valor*$valor;
$cub=$valor*$valor*$valor;
}
El parmetro $cuad se almacena en la variable $c1 y el parmetro $cub se almacena en $c2.
Es la forma ms adecuada de modificar variables dentro de una funcin.
31
Curso PHP
Problema a resolver
Confeccionar un formulario que solicite la carga del nombre de usuario y su clave en dos
oportunidades. En la pgina que se procesan los datos del formulario implementar una
funcin que imprima un mensaje si las dos claves ingresadas son distintas.
32
Curso PHP
33
Curso PHP
34
Curso PHP
die("Problemas en la seleccion de la base de datos");
mysql_query("insert into alumnos(nombre,mail,codigocurso) values
('$_REQUEST[nombre]','$_REQUEST[mail]',$_REQUEST[codigocurso])",
$conexion) or die("Problemas en el select".mysql_error());
mysql_close($conexion);
echo "El alumno fue dado de alta.";
?>
</body>
</html>
Veamos los pasos para efectuar el alta en la tabla alumnos:
$conexion=mysql_connect("localhost","root","z80")
or die("Problemas en la conexion");
La funcin mysql_connect se conecta a una base de datos de tipo MySql, el primer parmetro
es la direccin donde se encuentra el gestor de base de datos (en este caso en el mismo
servidor por lo que indicamos esto con "localhost), el segundo parmetro es el nombre de
usuario de la base de datos ("root" en nuestro caso, que es el usuario por defecto que crea
MySql para el administrador) y por ltimo la clave del usuario (cuando yo instal MySql defin
como clave la cadena "z80").
En caso de hacer algn error en la llamada a la funcin la misma retorna false por lo que se
ejecuta la instruccin seguida del operador or, en nuestro caso llamamos a la funcin die que
detiene la ejecucin del programa y muestra el mensaje por pantalla.
Paso seguido se selecciona una base de datos (ya que el gestor de base de datos puede
administrar varias bases de datos):
mysql_select_db("phpfacil",$conexion) or
die("Problemas en la seleccion de la base de datos");
A esta funcin le indicamos como primer parmetro el nombre de la base de datos con la que
trabajaremos y como segundo parmetro la referencia que retorn la funcin mysql_connect.
El paso ms importante es la codificacin del comando SQL insert:
mysql_query("insert into alumnos(nombre,mail,codigocurso) values
('$_REQUEST[nombre]','$_REQUEST[mail]',$_REQUEST[codigocurso])",
$conexion) or die("Problemas en el select".mysql_error());
La sintaxis del comando insert es bastante sencilla, indicamos el nombre de la tabla y los
campos de la tabla a cargar. Luego debemos indicar en el mismo orden los valores a cargar en
cada campo (dichos valores los rescatamos del formulario anterior).
Los campos de tipo varchar SQL requiere que encerremos entre comillas simples, esto sucede
para el nombre y el mail; en cambio, para el codigocurso esto no debe ser as.
Otra cosa a tener en cuenta es que los subndices de los vectores asociativos no deben ir
entre simples comillas ya que se encuentran dentro de un string, sino se producir un error.
En caso que MySql detecte un error, retorna false esta funcin, por lo que se ejecuta la
instruccin posterior al or, es decir la funcin die que mostrar el error generado por MySql
llamando a la funcin mysql_error().
Por ltimo cerramos la conexion con la base de datos y mostramos un mensaje indicando que
la carga se efectu en forma correcta.
Tener en cuenta que el campo cdigo se gener en forma automtica.
35
Curso PHP
Problema a resolver
Ya existe una tabla llamada: cursos en la base de datos: phpfacil. Efectuar el alta de la tabla.
La tabla cursos tiene la siguiente estructura:
CREATE TABLE `cursos` (
`codigo` int(11) NOT NULL auto_increment,
`nombrecur` varchar(40) NOT NULL,
PRIMARY KEY (`codigo`)
)
Es decir que, por teclado slo debemos cargar el nombre del curso (nombrecur).
36
Curso PHP
37
Curso PHP
Para rescatar registro a registro los datos obtenidos por el select debemos llamar a la funcin
mysql_fetch_array. Esta funcin retorna un vector asociativo con los datos del registro
rescatado, o false en caso de no haber ms registros. Es decir que si retorna un registro se
almacena en el vector $reg y la condicin del while se valida como verdadero y pasa a
ejecutarse el bloque del while:
{
echo "Codigo:".$reg['codigo']."<br>";
echo "Nombre:".$reg['nombre']."<br>";
echo "Mail:".$reg['mail']."<br>";
echo "Curso:";
switch ($reg['codigocurso']) {
case 1:echo "PHP";
break;
case 2:echo "ASP";
break;
case 3:echo "JSP";
break;
}
echo "<br>";
echo "<hr>";
}
El bloque del while muestra el contenido del registro rescatado por la funcin
mysql_fetch_array. Como vemos, para rescatar cada campo accedemos mediante el vector
asociativo $reg indicando como subndice un campo indicado en el select:$reg['codigo']
Cada vez que llamamos a la funcin mysql_fetch_array nos retorna el siguiente registro.
Cuando debemos mostrar el curso mediante la instruccin switch, analizamos si tiene un 1,2
3 y procedemos a mostrar el nombre del curso.
Para separar cada alumno en la pgina HTML llamamos disponemos la marca "<hr>
Problema a resolver
Confeccionar un programa que recupere los datos de la tabla cursos de la base de datos
phpfacil.
38
Curso PHP
39
Curso PHP
</html>
Lo ms importante est en el comando select:
$registros=mysql_query("select codigo,nombre, codigocurso
from alumnos where
mail='$_REQUEST[mail]'",$conexion) or
die("Problemas en el select:".mysql_error());
Ac es donde con la clausula where seleccionamos slo el registro que cumple con la
condicin que el mail sea igual al que ingresamos.
Como slo puede haber un registro que cumpla la condicin, llamamos a la funcin
mysql_fetch_array en un if:
if ($reg=mysql_fetch_array($registros))
En caso de retornar un vector asociativo la condicin del if se verifica como verdadera y pasa
a mostrar los datos, en caso de retornar false se ejecuta el else.
Problema a resolver
Confeccionar un programa que permita ingresar el nombre de un alumno en un formulario,
luego mostrar los datos del mismo (tener en cuenta que puede haber ms de un alumno con el
mismo nombre).
40
Curso PHP
41
Curso PHP
Problema a resolver
Confeccionar un programa que permita ingresar el nombre de un curso por teclado y
posteriormente efecte el borrado de dicho registro en la tabla cursos. Mostrar un mensaje si
no existe el curso.
42
Curso PHP
Problema a resolver
Efectuar el borrado de todos los registros de la tabla cursos.
43
Curso PHP
44
Curso PHP
{
?>
<form action="pagina3.php" method="post">
Ingrese nuevo mail:
<input type="text" name="mailnuevo" value="<?php
echo $reg['mail'] ?>">
<br>
<input type="hidden" name="mailviejo" value="<?php echo $reg['mail']
?>">
<input type="submit" value="Modificar">
</form>
<?php
}
Es decir que podemos disponer bloques de PHP dispersos dentro de la pgina.
Otro concepto importante es como enviar el mail del primer formulario a la tercer pgina,
esto se logra con los controles de tipo "hidden", este tipo de control no se visualiza en el
formulario pero se enva al presionar el botn submit.
Si queremos que el control text se inicialize con el mail ingresado en el formulario anterior
debemos cargar la propiedad value con dicho valor:
<input type="text" name="mailnuevo" value="<?php echo $reg['mail']
?>">
Por ltimo la pagina3.php es la que efecta la modificacin de la tabla propiamente dicha.
Con el mail ingresado en la pagina1.php, el mail modificado en la pagina2.php se efecta el
update.
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion=mysql_connect("localhost","root","z80") or
die("Problemas en la conexion");
mysql_select_db("phpfacil",$conexion) or
die("Problemas en la seleccin de la base de datos");
$registros=mysql_query("update alumnos
set mail='$_REQUEST[mailnuevo]'
where mail='$_REQUEST[mailviejo]'",$conexion)
or
die("Problemas en el select:".mysql_error());
echo "El mail fue modificado con exito";
?>
</body>
</html>
Tengamos en cuenta que el segundo formulario nos enva dos datos: $_REQUEST[mailnuevo] y
$_REQUEST[mailviejo].
Problema a resolver
Efectuar la modificacin del nombre del curso de la tabla "cursos". Para la bsqueda ingresar
el cdigo de curso.
45
Curso PHP
46
Curso PHP
die("Problemas en la conexion");
mysql_select_db("phpfacil",$conexion) or
die("Problemas en la seleccion de la base de datos");
mysql_query("insert into alumnos(nombre,mail,codigocurso) values
('$_REQUEST[nombre]', '$_REQUEST[mail]',
$_REQUEST[codigocurso])", $conexion) or
die("Problemas en el select".mysql_error());
mysql_close($conexion);
echo "El alumno fue dado de alta.";
?>
</body>
</html>
Problema a resolver
Confeccionar el alta de la tabla alumnos empleando controles de tipo "radio" para la seleccin
del curso.
47
Curso PHP
48
Curso PHP
alumnos. Cuando rescatamos los datos y los mostramos en la pgina, hacemos referencia al
alias del campo:
while ($reg=mysql_fetch_array($registros))
{
echo "Codigo:".$reg['codigo']."<br>";
echo "Nombre:".$reg['nombre']."<br>";
echo "Mail:".$reg['mail']."<br>";
echo "Curso:".$reg['nombrecur']."<br>";
echo "<hr>";
}
Problema a resolver
Confeccionar un programa que permita ingresar el cdigo de un alumno y nos muestre su
nombre, mail y nombre del curso en el cual est inscripto. Hacer un formulario donde se
ingrese el cdigo de alumno y otra pgina donde se muestren los datos respectivos. Mostrar
un mensaje si no existe el cdigo de alumno ingresado.
49
Curso PHP
Problema a resolver
Confeccionar un programa que muestre por pantalla los nombres de todos los cursos y al final
la cantidad total de cursos.
50
Curso PHP
51
Curso PHP
</select>
<br>
<input type="submit" value="Modificar">
</form>
<?php
}
else
echo "No existe alumno con dicho mail";
?>
</body>
</html>
La primera consulta de la tabla alumnos es para verificar si existe un alumno con el mail
ingresado por teclado:
$registros=mysql_query("select * from alumnos
where mail='$_REQUEST[mail]'",$conexion) or
die("Problemas en el select:".mysql_error());
if ($regalu=mysql_fetch_array($registros))
{
En caso de existir un alumno con dicho mail, el if se verifica verdadero y pasamos a poblar el
control select con los distintos cursos que contiene la tabla "cursos":
$registros=mysql_query("select * from cursos",$conexion) or
die("Problemas en el select:".mysql_error());
while ($reg=mysql_fetch_array($registros))
{
if ($regalu['codigocurso']==$reg['codigo'])
echo "<option value=\"$reg[codigo]\"
selected>$reg[nombrecur]</option>";
else
echo "<option value=\"$reg[codigo]\">$reg[nombrecur]</option>";
}
?>
</select>
Para que aparezca seleccionado el curso actual debemos inicializar lo marca option con el
texto selected. Es decir que el if dentro del while se verifica verdadero una solo vez.
Por ltimo la tercer pgina procede a registrar el cambio en la tabla "alumnos":
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion=mysql_connect("localhost","root","z80") or
die("Problemas en la conexion");
mysql_select_db("phpfacil",$conexion) or
die("Problemas en la seleccin de la base de datos");
$registros=mysql_query("update alumnos
set codigocurso=$_REQUEST[codigocurso]
where mail='$_REQUEST[mailviejo]'",$conexion)
or
die("Problemas en el select:".mysql_error());
echo "El curso fue modificado con exito";
?>
</body>
</html>
52
Curso PHP
Problema a resolver
Confeccionar la modificacin del mail, nombre y curso de la tabla "alumnos". Ingresar por
teclado el cdigo de alumno para su bsqueda.
53
Curso PHP
54
Curso PHP
echo "Cantidad de inscriptos:".$reg['cantidad']."<br>";
echo "<hr>";
}
Problema a resolver
Confeccionar un programa que muestre el nombre del curso, la cantidad de inscriptos y todos
los inscriptos a dicho curso. Repetir esto con todos los cursos.
Es decir, en la pgina debe aparecer algo parecido a:
Nombre del curso:PHP
Cantidad de inscriptos:3
Nombres: Martinez Luis - Rodriguez Pablo - Gonzalez Ana
Nombre del curso:JSP
Cantidad de inscriptos:2
Nombres: Hernandez Hector - Roca Marta
55
Curso PHP
56
Curso PHP
57
Curso PHP
</html>
Hay muchas cosas importantes en este ejemplo, lo primero que vemos es el bloque que
rescata a partir de qu registro ir mostrando:
if (isset($_REQUEST['pos']))
$inicio=$_REQUEST['pos'];
else
$inicio=0;
?>
La funcin isset retorna verdadero si existe la variable que le pasamos como parmetro, en
este caso le estamos pasando la componente pos del vector asociativo $_REQUEST. Cuando
llamamos por primera vez a esta pgina, lo hacemos : pagina1.php sin parmetros, por lo que
el if se verifica como falso. Es decir la variable $inicio se carga con el valor 0.
Otro concepto importante es la clusula limit que es propiedad del gestor MySQL. Mediante
esta clusula limitamos la cantidad de registros que retorna el select. El primer valor del limit
indica a partir de cual registro y el segundo la cantidad de registros. Es decir si un select sin
limit retorna 100 registro, luego utilizando por ejemplo la sintaxis limit 50,25 nos retornar,
de esa lista de 100 registros, a partir del registro de la posicin 50, 25 registros.
En nuestro problema indicamos que retorne desde valor que tenga la variable $inicio y como
cantidad 2 (pginas con 2 registros):
$registros=mysql_query("select alu.codigo as
codigo,nombre,mail,codigocurso,
nombrecur from alumnos as alu
inner join cursos as cur on
cur.codigo=alu.codigocurso
limit $inicio,2", $conexion) or
Seguidamente mostramos todos los registros retornados y adems los contamos:
$impresos=0;
while ($reg=mysql_fetch_array($registros))
{
$impresos++;
echo "Codigo:".$reg['codigo']."<br>";
echo "Nombre:".$reg['nombre']."<br>";
echo "Mail:".$reg['mail']."<br>";
echo "Curso:".$reg['nombrecur']."<br>";
echo "<hr>";
}
Ahora vemos dnde dispondremos los hipervnculos, hacia adelante o atrs:
if ($inicio==0)
echo "anteriores ";
else
{
$anterior=$inicio-2;
echo "<a href=\"pagina1.php?pos=$anterior\">Anteriores </a>";
}
Si la variable $inicio vale 0 significa que no hay registros antes de ste, por lo que slo
mostramos un texto "anteriores". En caso que la variable $inicio sea distinta de 0, se ejecuta
el else, donde disponemos un hipervnculo con la misma pgina e inicializando el parmetro
pos con el valor de $inicio menos 2.
Si el contador $impresos tiene el valor 2 significa que posiblemente hay ms registros por
mostrar y debemos disponer un hipervnculo con la misma pgina pero inicializando el
parmetro pos con el valor de $inicio ms 2:
58
Curso PHP
if ($impresos==2)
{
$proximo=$inicio+2;
echo "<a href=\"pagina1.php?pos=$proximo\">Siguientes</a>";
}
else
echo "siguientes";
Problema a resolver
Confeccionar un programa que muestre los registros de la tabla "cursos" con pginas de 3
registros.
59
Curso PHP
60
Curso PHP
copy($_FILES['foto']['tmp_name'],$_FILES['foto']['name']);
La matriz $_FILES almacena el nombre del archivo almacenado en el directorio temporal
($_FILES['foto']['tmp_name']) y el nombre del archivo originario ($_FILES['foto']['name'])
Por ltimo mostramos en la pgina el archivo que se almacen en el servidor:
$nom=$_FILES['foto']['name'];
echo "<img src=\"$nom\">";
Otras cosas interesantes que tiene la matriz $_FILES:
$_FILES['foto']['name'] El nombre original del fichero en la mquina cliente.
$_FILES['foto']['type'] El tipo de archivo (si el navegador lo proporciona). Un ejemplo podra
ser "image/gif".
$_FILES['foto']['size'] El tamao en bytes del fichero recibido.
$_FILES['foto']['tmp_name'] El nombre del archivo temporal que se utiliza para almacenar en
el servidor el archivo recibido.
Problema a resolver
Confeccionar un programa que permita hacer multiples upload con una pgina (por ejemplo
que permita seleccionar hasta 3 archivos)
61
Curso PHP
62
Curso PHP
El vector asociativo $_COOKIE almacena todas las cookies creadas por el visitante. Si es la
primera vez que peticionamos esta pgina, el vector $_COOKIE no tendr elementos.
Es decir que la marca body no tiene inicializada la propiedad bgcolor.
La segunda pgina es la que crea la cookie propiamente dicha:
<?php
if ($_REQUEST['radio']=="rojo")
setcookie("color","#ff0000",time()+60*60*24*365,"/");
elseif ($_REQUEST['radio']=="verde")
setcookie("color","#00ff00",time()+60*60*24*365,"/");
elseif ($_REQUEST['radio']=="azul")
setcookie("color","#0000ff",time()+60*60*24*365,"/");
?>
<html>
<head>
<title>Problema</title>
</head>
<body>
Se cre la cookie.
<br>
<a href="pagina1.php">Ir a la otra pgina</a>
</body>
</html>
La llamada a la funcin setcookie debe hacerse antes de imprimir cualquier marca HTML, de
lo contrario no funcionar.
Como podemos observar, la creacin de la cookie se hace llamando a la funcin setcookie:
<?php
if ($_REQUEST['radio']=="rojo")
setcookie("color","#ff0000",time()+60*60*24*365,"/");
elseif ($_REQUEST['radio']=="verde")
setcookie("color","#00ff00",time()+60*60*24*365,"/");
elseif ($_REQUEST['radio']=="azul")
setcookie("color","#0000ff",time()+60*60*24*365,"/");
?>
El nombre de la cookie se llama "color" y el valor que almacenamos depende de qu control
de tipo radio est seleccionado en la pgina anterior. La fecha de expiracin de la cookie la
calculamos fcilmente llamando a la funcin time() que nos retorna la fecha actual en
segundos y le sumamos el producto 60*60*24*365 (60 segundos * 60 minutos * 24 horas * 365
das) es decir que la cookie existir en la mquina del visitante hasta el ao prximo.
Cuando indicamos como directorio la sintaxis "/" significa que la cookie se crea a nivel del
sitio y con cuaquier peticin a dicho sitio, el navegador enviar la cookie al servidor.
Por ltimo dispusimos en esta pgina un hipervnculo a la pgina anterior, para ver que, de
ahora en ms, cada vez que ejecutemos la pagina1.php, el color de fondo de la misma
depender del valor de la cookie registrada.
Problema a resolver
Crear una cookie que almacene el nombre del visitante al sitio y cada vez que ingresemos al
sitio nos de la bienvenida imprimiendo nuestro nombre. Para cargar el nombre crear un
formulario con un control de tipo text.
63
Curso PHP
64
Curso PHP
En esta pgina verificamos cul control radio est seleccionado, si es el primero, creamos la
cookie mail con una vida de 1 ao:
setcookie("mail",$_REQUEST['mailusuario'],time()+(60*60*24*365),"/");
En caso que est seleccionado el segundo radio, creamos la misma cookie pero con una fecha
de caducidad inferior a la actual (con esto estamos virtualmente eliminando la cookie):
setcookie("mail","",time()-1000,"/");
Problema a resolver
Confeccionar una pgina que simule ser la de un peridico. La misma debe permitir configurar
qu tipo de titular deseamos que aparezca al visitarla, pudiendo ser:
Noticia poltica, Noticia econmica o Noticia deportiva.
Mediante tres objetos de tipo radio, permitir seleccionar qu titular debe mostrar el
peridico. Almacenar en una cookie el tipo de titular que desea ver el cliente. La primera vez
que visita el sitio deben aparecer los tres titulares.
65
Curso PHP
66
Curso PHP
67
Curso PHP
las variables de sesin</a>
</body>
</html>
Cuando creamos o accedemos al contenido de variables de sesin debemos llamar a la funcin
session_start() antes de cualquier salida de marcas HTML.
Para almacenar los valores en las variables de sesin lo hacemos:
$_SESSION['usuario']=$_REQUEST['campousuario'];
$_SESSION['clave']=$_REQUEST['campoclave'];
Es decir, tenemos el vector asociativo $_SESSION que almacena las variables de sesin.
Por ltimo, esta pgina tiene un hipervnculo a la tercera pgina.
La ltima pgina de este ejemplo tiene por objetivo acceder a las variables de sesin:
<?php
session_start();
?>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo "Nombre de usuario recuperado de la variable de
sesin:".$_SESSION['usuario'];
echo "<br><br>";
echo "La clave recuperada de la variable de
sesin:".$_SESSION['clave'];
?>
</body>
</html>
De nuevo vemos que la primera lnea de esta pgina es la llamada a la funcin session_start()
que, entre otras cosas, rescata de un archivo de texto las variables de sesin creadas para ese
usuario (recordemos que desde el navegador todas las veces retorna una cookie con la clave
que gener PHP la primera vez que llamamos a una pgina del sitio).
Para mostrar las variables de sesin, las accedemos por medio del vector asociativo
$_SESSION:
echo "Nombre de usuario recuperado de la variable de
sesin:".$_SESSION['usuario'];
echo "<br><br>";
echo "La clave recuperada de la variable de
sesin:".$_SESSION['clave'];
Tengamos en cuenta que en cualquier otra pgina del sitio tenemos acceso a las variables de
sesin slo con llamar inicialmente a la funcin session_start().
Problema a resolver
Confeccionar un formulario que solicite ingresar el mail de un alumno. Si el mail existe en la
tabla alumnos, rescatar su nombre y almacenarlo en una variable de sesin. Adems disponer
un hipervnculo a una tercera pgina que verifique si existe la variable de sesin y de la
bienvenida al alumno, en caso contrario mostrar un mensaje indicando que no puede visitar
esta pgina (para saber si una variable de sesin est definida llamamos a la funcin isset)
if (isset($_SESSION['nombre'])) ....
68
Curso PHP
69
Curso PHP
echo "<table width=\"50%\" align=\"center\"><tr><td
bgcolor=\"#cccccc\">$tit</td></tr></table>";
}
?>
Normalmente las rutinas se tratan de archivos PHP puros, es decir que contienen slo
funciones y no marcas HTML fijas. Es importante el lugar donde llamamos a la funcin
require_once, debe ser siempre antes de la llamada a las funciones que contiene la librera.
Problema a resolver
Confeccionar una librera que contenga una funcin llamada retornarConexion, la misma debe
llamar a las funciones mysql_connect y mysql_select_db y retornar la variable que gener la
funcin mysql_connect.
Tener en cuenta que a esta funcin la deben implementar en el archivo "pagina2.php".
En el archivo "pagina1.php" incluir la librera que contiene la funcin retornarConexion. Luego
imprimir todos los registros de la tabla alumnos.
70
Curso PHP
71
Curso PHP
if (isset($_REQUEST['error']))
echo "Ingreso clave incorrecta";
?>
72
Curso PHP
73
Curso PHP
$rojo=ImageColorAllocate($imagen,255,0,0);
$valoraleatorio=rand(100000,999999);
ImageString($imagen,5,25,5,$valoraleatorio,$rojo);
Recordemos que la funcin rand nos retorna un valor aleatorio comprendido entre los dos
valores que le pasamos como parmetro. Seguidamente, con la funcin ImageString
imprimimos el nmero generado de color rojo en las coordenadas 25,5 y con un tamao de
fuente 5 (valores posibles de fuente son de 1 a 5).
Tenemos dibujado el cdigo verificador (en nuestro caso es un nmero verificador, ya que no
hemos incorporado caracteres) ahora para hacer ms dificil la lectura del nmero
incorporaremos una serie de segmentos que tapen en forma parcial el nmero aleatorio:
for($c=0;$c<=5;$c++)
{
$x1=rand(0,$ancho);
$y1=rand(0,$alto);
$x2=rand(0,$ancho);
$y2=rand(0,$alto);
ImageLine($imagen,$x1,$y1,$x2,$y2,$rojo);
}
Disponemos un for para que dibuje 6 lneas. Para graficar las lneas llamamos a la funcin
ImageLine que tiene cuatro parmetros fundamentales que son las coordenadas de los dos
puntos de origen y fin de la lnea. Como sabemos el ancho y alto de la imagen y para que la
lnea se encuentre dentro de los lmites del grfico, disponemos como valor mximo los
valores almacenados en $ancho y $alto.
Hasta aca la imagen se encuentra en memoria, debemos adems indicar qu formato tendr y
enviarla al cliente que la solicit:
Header ("Content-type: image/jpeg");
ImageJPEG ($imagen);
ImageDestroy($imagen);
Tambin en este tipo de problemas requerimos la funcin header (recordemos que la
empleamos en el redireccionamiento) Indicamos el tipo de archivo que recibir el navegador.
Llamamos en este caso a la funcin ImageJPEG (podramos llamar tambin a ImagePNG,
ImageGIF, etc.) que genera la informacin de la imagen propiamente dicha y por ltimo
llamamos a la funcin ImageDestroy para liberar los recursos ocupados en el servidor por este
proceso de generacin de la imagen.
Problema a resolver
Confeccionar una imagen dinmica que represente un botn. Utilizar las funciones vistas para
imprimir el texto del botn y para rellenar regiones del grfico, emplear la funcin
imageFilledRectange. ImageFilledRectangle crea un rectngulo relleno con color "col" en la
imagen "imagen", comenzando con la coordenada superior izquierda (x1, y1) y finalizando en
la coordenada inferior derecha (x2, y2).
imagefilledrectangle ( imagen,x1,y1,x2,y2,col)
Recordar que debe ser PHP puro, por lo que deber borrar todo el cdigo HTML que se
encuetra fuera de las marcas:
<?php ?>
74
Curso PHP
75
Curso PHP
Header ("Content-type: image/jpeg");
ImageJPEG ($imagen);
ImageDestroy($imagen);
?>
El algoritmo es el mismo visto en un concepto anterior, la nica salvedad es que necesitamos
almacenar en una variable de sesin, el nmero aleatorio para poder compararlo en la pgina
que procesa el formulario:
session_start();
$_SESSION['numeroaleatorio']=$valoraleatorio;
Por ltimo el tercer archivo "pagina3.php":
<?php
session_start();
?>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
if ($_SESSION['numeroaleatorio']==$_REQUEST['numero'])
echo "Ingres el valor correcto";
else
echo "Incorrecto";
?>
</body>
</html>
Lo primero que hacemos es llamar a la funcin que rescata las variables de sesin:
<?php
session_start();
?>
Disponemos un if para verificar si el valor ingresado en el formulario es el mismo que el valor
almacenado en la variable de sesin:
if ($_SESSION['numeroaleatorio']==$_REQUEST['numero'])
echo "Ingres el valor correcto";
else
echo "Incorrecto";
Problema a resolver
Confeccionar un formulario que pida ingresar la direccin de un sitio de internet y mediante
un control de tipo select permita dar un puntaje a la misma (cargar los valores de 0 a 5).
Luego, en la segunda pgina, imprimir el nombre del sitio y un grfico creado en forma
dinmica con el puntaje obtenido (hacer un crculo por cada punto).
Un poco de ayuda para este problema:
En el archivo "pagina2.php" debemos disponer la marca HTML img para mostrar la imagen y
debemos pasar a este archivo el valor que nos lleg del formulario, es decir, el puntaje
seleccionado:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
76
Curso PHP
echo "La direccion: $_REQUEST[direccion] tiene";
?>
<img src="pagina3.php?puntos=<?php echo $_REQUEST['puntos'];?>">
</body>
</html>
Por ltimo, queda como actividad, dibujar tantos crculos como indica el parmetro puntos:
Recordemos que para recuperar el parmetro puntos lo accedemos mediante el vector
asociativo $_REQUEST:
REQUEST['puntos']
Para dibujar los crculos rellenos debemos emplear la funcin:
imagefilledellipse ( <manejador de imagen>, <centro en x>,
<centro en y>, <ancho del elipse>,
<alto del elipse>,<manejador de color>)
77
Curso PHP
78
Curso PHP
Por ltimo, a los otros caracteres de formato de la funcin date que nos pueden servir en
alguna ocasin, los podemos ver en el siguiente ejemplo:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$dato=date("L");
if ($dato==1)
echo "Ao bisiesto";
else
echo "Ao no bisiesto";
echo "<br>";
echo "Da de la semana:";
$dato=date("w");
switch ($dato) {
case 0: echo "domingo";
break;
case 1: echo "lunes";
break;
case 2: echo "martes";
break;
case 3: echo "mircoles";
break;
case 4: echo "jueves";
break;
case 5: echo "viernes";
break;
case 6: echo "sbado";
break;
}
?>
</body>
</html>
Los caracteres son:
L "1" or "0", segn si el ao es bisiesto o no
w da de la semana, en nmero, de "0" (domingo) a "6" (sbado)
Problema a resolver
Confeccionar un programa que permita registrar una queja en un archivo de texto.Disponer
un formulario que permita almacenar el nombre del visitante (objeto HTML de tipo "text"), la
descripcin de la queja (objeto de tipo "textarea").
Almacenar en el archivo de texto la fecha y hora de la queja.
El archivo "pagina1.php" debe ser el formulario de ingreso de datos.
El archivo "pagina2.php" debe registrar la informacin en el archivo de datos.
Por ltimo el archivo "pagina3.php" debe imprimir el archivo con todas las quejas registradas
hasta el momento. Disponer un hipervnculo en el archivo "pagina1.php" para poder ver todas
las quejas registradas.
Recordar que el archivo de texto obligatoriamente debe llamarse: "datos.txt".
79
Curso PHP
80
Curso PHP
else
echo "La fecha no es vlida";
}
else
echo "La fecha no es vlida";
?>
</body>
</html>
Problema a resolver
Confeccionar un formulario que solicite la carga de una fecha, disponer tres controles HTML
de tipo "select" para elegir el da, el mes y el ao. Validar si se trata de una fecha vlida en la
segunda pgina.
81
Curso PHP
82
Curso PHP
mysql_select_db("phpfacil",$conexion) or
die("Problemas en la seleccion de la base de datos");
$fechanacimiento=$_REQUEST['anio']."-".$_REQUEST['mes']."".$_REQUEST['dia'];
mysql_query("insert into alumnos(nombre,mail,codigocurso,fechanac)
values
('$_REQUEST[nombre]','$_REQUEST[mail]',
$_REQUEST[codigocurso],'$fechanacimiento')", $conexion) or
die("Problemas en el select".mysql_error());
mysql_close($conexion);
echo "El alumno fue dado de alta.";
?>
<br>
<a href="pagina3.php">ver listado de alumnos</a>
</body>
</html>
Lo primero que hacemos es generar una string que contenga el ao-mes-da, en ese orden y
utilizando como separador el caracter "-":
$fechanacimiento=$_REQUEST['anio']."-".$_REQUEST['mes']."".$_REQUEST['dia'];
Tenemos ahora en la variable $fechanacimiento el valor de la fecha ingresada por teclado con
el formato que requiere el MySql, procedemos ahora a plantear el comando insert con todos
los datos ingresados en el formulario:
mysql_query("insert into alumnos(nombre,mail,codigocurso,fechanac)
values
('$_REQUEST[nombre]','$_REQUEST[mail]',
$_REQUEST[codigocurso],'$fechanacimiento')", $conexion) or
die("Problemas en el select".mysql_error());
Por ltimo, dispusimos un hipervnculo a una tercera pgina donde mostramos el contenido de
la tabla alumnos, aqu podremos controlar los datos ingresados.
No hemos validado la fecha ingresada, tarea obligatoria cuando implementemos un sitio real.
El ltimo archivo contiene la pgina que imprime el contenido de la tabla alumnos, con el
campo fechanac inclusive:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion=mysql_connect("localhost","root","z80") or
die("Problemas en la conexion");
mysql_select_db("phpfacil",$conexion) or
die("Problemas en la seleccin de la base de datos");
$registros=mysql_query("select alu.codigo as codigo,nombre,mail,
codigocurso,fechanac,nombrecur from alumnos
as alu
inner join cursos as cur on
cur.codigo=alu.codigocurso",
$conexion) or
die("Problemas en el select:".mysql_error());
while ($reg=mysql_fetch_array($registros))
{
echo "Codigo:".$reg['codigo']."<br>";
echo "Nombre:".$reg['nombre']."<br>";
echo "Mail:".$reg['mail']."<br>";
83
Curso PHP
echo "Fecha de Nacimiento:".$reg['fechanac']."<br>";
echo "Curso:".$reg['nombrecur']."<br>";
echo "<hr>";
}
mysql_close($conexion);
?>
</body>
</html>
Problema a resolver
Confeccionar un programa que permita efectuar el alta en la tabla alumnos. Para el ingreso
de la fecha de nacimiento del alumno, disponer 3 controles de tipo "select" (en el da
disponer valores entre 1 y 31, en el mes valores comprendidos entre 1 y 12 y por ltimo en el
ao disponer valores comprendidos entre 1900 y 2006)
Validar la fecha en la pgina que se efecta el insert propiamente dicho.
Recomendacin: Plantear una estructura repetitiva de PHP para la creacin del control
"select" donde se selecciona el ao de nacimiento.
84
Curso PHP
85
Curso PHP
conversin a hexadecimal. Recordemos que la propiedad bgcolor de la
marca body, lo requiere en hexadecimal.<br><br>
<a href="pagina3.php">ltimo ejemplo</a>
</body>
</html>
La funcin printf puede formatear n datos en una nica llamada, como ocurre en este caso:
<body bgcolor="<?php printf("#%X%X%X",150,150,0); ?>">
Cuando tenemos los tres valores en formato decimal, para crear un color, la funcin printf
nos facilita la tarea de generar el color definitivo en hexadecimal.
Por ltimo, con la funcin printf, podemos determinar el nmero de caracteres que va a
ocupar o en su defecto se rellenar con ceros:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$dia=6;
$mes=5;
$anio=2006;
printf("%02d/%02d/%d",$dia,$mes,$anio);
?>
</body>
</html>
Con esto logramos que una fecha aparezca con el da y el mes siempre de dos dgitos.
Si deseamos rellenar con otro caracter debemos disponer una simple comilla y el caracter a
rellenar:
$importe=170;
printf("Valor:$%'x7d",$importe);
Problema a resolver
Confeccionar un formulario que solicite la carga del nombre de una persona, su mail y un
importe que desea donar.
En la pgina que procesa los datos ingresados, mostrar el importe a donar rellenando con
ceros, por ejemplo: $0000170 dolares.
86
Curso PHP
87