PHP Programación
PHP Programación
Hay que entender primero como funciona la solicitud de páginas en un navegador para
comenzar a programar en PHP.
3 - El web server (servidor web, que puede ser el Apache, IIS, etc.) que es un programa que
se ejecuta en la máquina www.lanacion.com, recibe el mensaje y lee el archivo solicitado
desde el disco duro.
4 - El servidor web envía el archivo solicitado por el navegador tal cual está en el disco
duro.
Este proceso siempre es el mismo cuando hablamos de páginas estáticas (páginas que no
cambian), cualquiera sea el cliente que solicita la página el contenido siempre será el
mismo.
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 envíe el archivo.
El comando de PHP para imprimir dentro de la página se llama echo. Nuestro programa
"Hola Mundo" será entonces:
<html>
<head></head>
<body>
<?php
echo "Hola Mundo";
?>
</body>
</html>
Es decir que la página que se generará al ejecutarse el programa será:
<html>
<head></head>
<body>
Hola Mundo
</body>
</html>
Podemos utilizar como editor de texto para codificar el programa PHP el NotePad++.
Para verificar si la variable $dia es menor o igual a 10, debemos emplear la instrucción if,
similar a otros lenguajes.
Entonces la página con el programa queda de la siguiente forma:
<html>
<head></head>
<body>
<?php
$dia=date("d");
if ($dia<=10)
else
?>
</body>
</html>
Sabiendo que la función 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 además si es
menor o igual a 50 o si es mayor.
Para imprimir el contenido de una variable también utilizamos el comando echo:
echo $num;
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$num=rand(1,100);
echo $num;
echo "<br>";
if ($num<=50)
else
{
echo "El número es mayor a 50.";
?>
</body>
</html>
El primer ejemplo que haremos es mostrar en la página los números del 1 al 100:
html>
<head>
<title>Problema</title>
</head>
<body>
<?php
for($f=1;$f<=100;$f++)
{
echo $f;
echo "<br>";
}
?>
</body>
</html>
Esta estructura está en casi todos los lenguajes. El bloque se repite mientras la condición del while
sea verdadera.
La condición del while se verifica antes de ingresar al bloque a repetir. Si la misma se verifica falsa
la primera vez no se ejecutará el bloque.
Veamos un ejemplo: Generar un valor aleatorio entre 1 y 100, luego imprimir en la página desde 1
hasta el valor generado (de uno en uno):
<html>
<head>
<title>Problema</title>
</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 instrucción inmediatamente siguiente a la
llave de cerrado.
Es importante notar que luego de la condición del while NO disponemos PUNTO y COMA.
Por último tenemos en el lenguaje una estructura repetitiva similar al while llamada do/while,
donde la condición se verifica luego de ejecutarse el bloque repetitivo.
do
{
[Instrucciones];
} while (condición);
Queda como tarea intentar hacer una página empleando esta estructura. Tener en cuenta que al
final de la línea del do/while SI LLEVA punto y coma.
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$dia=date("d");
$inicio=1;
while($inicio<=$dia)
echo $inicio."<br>";
$inicio++;
?>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo "Tabla del 2 con el for";
echo "<br>";
for($f=2;$f<=20;$f=$f+2)
echo $f;
echo "-";
echo "<br>";
echo "<br>";
$f=2;
while ($f<=20)
echo $f;
echo "-";
$f=$f+2;
echo "<br>";
echo "<br>";
$f=2;
do {
echo $f;
echo "-";
$f=$f+2;
} while ($f<=20);
?>
</body>
</html>
<html>
<head>
<title>Formulario de entrada del dato</title>
</head>
<body>
<form method="post" action="pagina2.php">
Ingrese su nombre:
<input type="text" name="nombre">
<br>
<input type="submit" value="confirmar">
</form>
</body>
</html>
Esta página está completamente codificada en HTML, es decir un formulario contiene marcas
HTML puras.
La marca <form> y </form> nos permite definir un formulario en la página. La marca FORM tiene
dos propiedades que debemos inicializar obligatoriamente: action y method. La propiedad action
indica el nombre del archivo que recibirá los datos ingresados por el operador en el formulario y
que serán enviados al servidor cuando se presione el botón (submit). La propiedad method indica
como se organizan esos datos para enviarlos al servidor, pudiendo ser mediante los métodos post
o get (normalmente los datos de un formulario se envían mediante el método post).
Para crear un cuadro de texto para el ingreso del nombre debemos definir un objeto de tipo "text"
y darle un nombre:
<input type="text" name="nombre">
La propiedad type nos permite definir el tipo de control y con la propiedad name indicamos el
nombre del control.
Por último todo formulario tiene un botón de tipo submit:
<input type="submit" value="confirmar">
También utilizamos la marca input pero en la propiedad type indicamos que se trata de un botón
de envío de datos. En la propiedad value indicamos el texto que queremos que aparezca en el
botón.
Ahora necesitamos una página con un pequeño programa en PHP que procese los datos
ingresados en el formulario:
<html>
<head>
<title>Captura de datos del form</title>
</head>
<body>
<?php
echo "El nombre ingresado es:";
echo $_REQUEST['nombre'];
?>
</body>
</html>
Para acceder al dato en PHP se cuenta con un vector llamado $_REQUEST indicando como
subíndice el nombre del cuadro de texto que definimos en el formulario (dicho nombre es sensible
a mayúsculas y minúsculas)
En nuestro problema sólo mostramos por pantalla el valor ingresado en la página anterior:
echo $_REQUEST['nombre'];
Pagina 1
<html>
<head>
<title>Problema</title>
</head>
<body>
Ingrese el nombre:
<br>
Ingrese la edad:
</form>
</body>
</html>
Pagina 2
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo $_REQUEST['nombre'];
echo "<br>";
if ($_REQUEST['edad']>=18)
else
?>
</body>
</html>
FORMULARIO (control radio)
Para analizar este control dispondremos un ejemplo:
Implementar un formulario que solicite la carga de dos enteros, uno en cada text. Disponer
dos controles de tipo radio que nos permitan seleccionar si queremos sumar o restar los dos
valores ingresados:
<html>
<head>
<title>Problema</title>
</head>
<body>
<form action="pagina2.php"
method="post">
Ingrese primer valor:
<input type="text" name="valor1">
<br>
Ingrese segundo valor:
<input type="text" name="valor2">
<br>
<input type="radio" name="radio1" value="suma">sumar
<br>
<input type="radio" name="radio1" value="resta">restar
<br>
<input type="submit" name="operar">
</form>
</body>
</html>
Es importante notar que se trata nuevamente de un archivo HTML puro, que no tiene código PHP.
La entrada de los dos números se efectúa en dos controles
<input type="text" name="valor1"> <input type="text" name="valor2">
Es importante notar que cada text tiene un name DIFERENTE.
Para seleccionar el tipo de operación a efectuar disponemos dos controles de tipo radio:
<input type="radio" name="radio1" value="suma">sumar<br> <input
type="radio" name="radio1" value="resta">restar
Es importante notar que los dos controles tienen el MISMO nombre. Esto es necesario para que el
navegador sepa que los dos controles están relacionados (recordar que cuando uno selecciona un
radio se debe deseleccionar el otro)
Desde la otra página accederemos al value del control seleccionado.
Por último disponemos un control de tipo submit para el envío de los datos del formulario.
El código de la página que procesa el formulario, llamada:"pagina2.php" (la que indicamos en la
marca FORM del formulario) es:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
if ($_REQUEST['radio1']=="suma")
{
$suma=$_REQUEST['valor1'] + $_REQUEST['valor2'];
echo "La suma es:".$suma;
}
else
{
if ($_REQUEST['radio1']=="resta")
{
$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" según cual se seleccionó en el formulario.
Con dos if verificamos cual operación está seleccionada y procedemos a efectuarla:
if ($_REQUEST['radio1']=="suma")
{
$suma=$_REQUEST['valor1'] + $_REQUEST['valor2'];
echo "La suma es:".$suma;
Ejercicios.
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 página que procesa el formulario mostrar el nombre de la persona y un
mensaje indicando el tipo de estudios que posee.
Pagina 1
<html>
<head>
<title>Problema</title>
</head>
<body>
Ingrese Nombre:
<br>
Estudios:
<br>
<br>
<br>
<br>
</form>
</body>
</html>
Pagina 2
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo $_REQUEST['nombre'];
echo "<br>";
if ($_REQUEST['radio1']=="sin")
if ($_REQUEST['radio1']=="primario")
if ($_REQUEST['radio1']=="secundario")
?>
</body>
</html>
<head>
<title>Problema</title>
</head>
<body>
<form action="pagina2.php"
method="post">
Ingrese primer valor:
<input type="text" name="valor1">
<br>
Ingrese segundo valor:
<input type="text" name="valor2">
<br>
<input type="checkbox" name="check1">sumar
<br>
<input type="checkbox" name="check2">restar
<br>
<input type="submit" name="operar">
</form>
</body>
</html>
Lo nuevo en este problema son los dos controles de tipo checkbox:
<input type="checkbox" name="check1">sumar
<br>
<input type="checkbox" name="check2">restar
<br>
Es importante notar que cada checkbox tiene un nombre distinto.
<html>
<head>
<title>Problema</title>
</head>
<body>
Ingrese el nombre:
<br>
<br>
<br>
<br>
<br>
</form>
</body>
</html>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$cant=0;
if (isset($_REQUEST['check1']))
$cant++;
if (isset($_REQUEST['check2']))
$cant++;
if (isset($_REQUEST['check3']))
$cant++;
if (isset($_REQUEST['check4']))
$cant++;
echo $_REQUEST['nombre'];
?>
</body>
</html>
<html>
<head>
<title>Problema</title>
</head>
<body>
<form action="pagina2.php"
method="post">
Ingrese primer valor:
<input type="text" name="valor1">
<br>
Ingrese segundo valor:
<input type="text" name="valor2">
<br>
<select name="operacion">
<option value="suma">sumar</option>
<option value="resta">restar</option>
</select>
<br>
<input type="submit" name="operar">
</form>
</body>
</html>
Lo nuevo que aparece en este formulario es el control de tipo select.
<select name="operacion">
<option value="suma">sumar</option>
<option value="resta">restar</option>
</select>
Cada opción tiene un valor. El seleccionado es el que se enviará a la página que procesa el
formulario. El texto que aparece dentro del control es el que disponemos entre las marcas option.
Confeccionar un formulario que solicite el ingreso del nombre de una persona y un combo de
selección (en este último permitir la selección de los ingresos mensuales de la persona: 1-
1000,1001-3000,>3000)
En la página que procesa el formulario mostrar un mensaje si debe pagar impuestos a las
ganancias (si supera 3000).
<html>
<head>
<title>Problema</title>
</head>
<body>
Ingrese el nombre:
<select name="ingresos">
<option value="1">1-1000</option>
<option value="2">1001-3000</option>
<option value="3">>3000</option>
</select>
<br>
</form>
</body>
</html>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo $_REQUEST['nombre'];
if ($_REQUEST['ingresos']==3)
else
{
echo " no debe pagar impuestos a las ganancias.";
?>
</body>
</html>
<html>
<head>
<title>Problema</title>
</head>
<body>
<form action="pagina2.php" method="post">
Ingrese nombre:<input type="text" name="nombre"><br>
Ingrese su curriculum:<br>
<textarea name="curriculum"></textarea>
<br>
<input type="submit" value="Confirmar">
</form>
</body>
</html>
La sintaxis de este control es bastante diferente a la del control text:
<textarea name="curriculum"></textarea>
Si queremos que aparezca inicializado con texto debemos disponerlo en:
<textarea name="curriculum">Hola Mundo</textarea>
La página PHP que procesa los dos datos ingresados en el formulario es:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo "El nombre ingresado:".$_REQUEST['nombre'];
echo "<br>";
echo "El curriculum:".$_REQUEST['curriculum'];
?>
</body>
</html>
Vectores (tradicionales)
Un Array es una colección de valores. Los array pueden ser unidimensionales (vectores),
bidimensionales (matrices) y multidimensionales (más de dos dimensiones)
Los arrays se utilizan ampliamente en el lenguaje PHP.
Se utiliza el delimitador [] para acceder a los diferentes elementos del vector.
$dias[0]=31;
$dias[1]=28;
Luego de estas dos líneas, tenemos creado un vector de dos elementos, a los cuales accedemos
por un subíndice que comienza a numerarse desde cero.
echo $dias[0]; //31
echo $dias[1]; //28
El vector, como podemos ver, puede ir creciendo en forma dinámica, es decir que si ahora
hacemos:
$dias[2]=31;
el vector tiene 3 componentes.
Si necesitamos conocer el tamaño del vector en cualquier momento podemos llamar a la función
count.
echo count($dias); //3
Vectores (tradicionales)
Definir un vector con los nombres de los días de la semana. Luego imprimir el primero y el último
elemento del vector.
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$diaSemana[]="Lunes";
$diaSemana[]="Martes";
$diaSemana[]="Miércoles";
$diaSemana[]="Jueves";
$diaSemana[]="Viernes";
$diaSemana[]="Sábado";
$diaSemana[]="Domingo";
echo "<br>";
?>
</body>
</html>
<html>
<head>
<title>Problema</title>
</head>
<body> <form action="pagina2.php" method="post">
Ingrese su nombre:
<input type="text" name="nombre">
<br>
Comentarios:
<br>
<textarea name="comentarios" rows="10" cols="40">
</textarea>
<br>
<input type="submit" value="Registrar">
</form>
</body>
</html>
Este formulario es similar a los planteados en problemas anteriores, sólo le hemos agregado al
control textarea, las propiedades rows y cols que dimensionan el mismo en la pantalla:
<textarea name="comentarios" rows="10" cols="40">
</textarea>
Veamos ahora la página (pagina2.php) que graba los datos cargados en el formulario en un
archivo:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$ar=fopen("datos.txt","a") or
die("Problemas en la creacion");
fputs($ar,$_REQUEST['nombre']);
fputs($ar,"\n");
fputs($ar,$_REQUEST['comentarios']);
fputs($ar,"\n");
fputs($ar,"--------------------------------------------------------");
fputs($ar,"\n");
fclose($ar);
echo "Los datos se cargaron correctamente.";
?>
</body>
</html>
Para la grabación de datos utilizamos la función fputs que tiene dos parámetros: la referencia al
archivo donde grabamos y el string a grabar.
fputs($ar,$_REQUEST['nombre']);
fputs($ar,"\n");
Para el salto de línea en el archivo de texto, usamos los caracteres \n.De esta forma cuando
leamos el archivo de texto lo haremos línea a línea. Cuando dejamos de trabajar con el archivo
llamamos a la función fclose.
Hay que tener muy presente que el archivo se almacena en el servidor y no en la máguina de la
persona que está navegando. Es decir, no vaya al explorador de archivos para ver donde se
almacenó "datos.txt", tenga en cuenta que está en la máquina donde se ejecutó el script de PHP.
Luego veremos como leer el contenido del archivo y mostrarlo en otra página del sitio (En nuestro
caso como utilizamos el equipo como cliente/servidor el archivo datos.txt se crea en la misma
carpeta donde se alojan nuestras páginas php)
Napolitana:[x]
Cantidad[...]
Muzzarella;[x]
Cantidad[...]
[Confirmar]
Para el ingreso del nombre, dirección y cantidad de pizzas de cada tipo disponer objetos de la clase
"text".
Disponer tres objetos de tipo "checkbox" para seleccionar los tipos de pizzas.
Por último disponer un botón para el envío de datos: "submit".
Grabar en un archivo de texto llamado "pedidos.txt" cada pedido, separados por una línea de
puntos entre cada pedido.
Solución
<html>
<head>
<title>Problema</title>
</head>
<body>
Nombre:
<br>
Dirección:
<br>
Jamon y Queso:
<input type="checkbox" name="jamonqueso">
<br>
Napolitana:
<br>
Muzzarella:
<br>
</form>
</body>
</html>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$ar=fopen("datos.txt","a") or
die("Problemas en la creacion");
fputs($ar,"Nombre:");
fputs($ar,$_REQUEST['nombre']);
fputs($ar,"\n");
fputs($ar,"Dirección:");
fputs($ar,$_REQUEST['direccion']);
fputs($ar,"\n");
if (isset($_REQUEST['jamonqueso']))
fputs($ar,$_REQUEST['cantjamonqueso']);
fputs($ar,"\n");
if (isset($_REQUEST['napolitana']))
fputs($ar,"Cantidad de Napolitana:");
fputs($ar,$_REQUEST['cantnapolitana']);
fputs($ar,"\n");
if (isset($_REQUEST['muzzarella']))
fputs($ar,"Cantidad de Muzzarella:");
fputs($ar,$_REQUEST['cantmuzzarella']);
fputs($ar,"\n");
fputs($ar,"--------------------------------------------------------");
fputs($ar,"\n");
fclose($ar);
?>
</body>
</html>
Para mostrar por pantalla el contenido del archivo "datos.txt" creado en el punto anterior
tenemos el siguiente programa:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$ar=fopen("datos.txt","r") or
die("No se pudo abrir el archivo");
while (!feof($ar))
{
$linea=fgets($ar);
$lineasalto=nl2br($linea);
echo $lineasalto;
}
fclose($ar);
?>
</body>
</html>
Vectores (asociativos)
Este tipo de vectores no es común a otros lenguajes, pero en PHP son de uso indispensable
en distintas situaciones (ya lo empleamos cuando recuperamos información de un
formulario accediendo al vector $_REQUEST que crea PHP en forma automática, cuando
accedamos a datos de una base de datos también lo emplearemos etc.)
Un vector asociativo permite acceder a un elemento del vector por medio de un subíndice
de tipo string.
Inicialmente uno piensa que esto nos complica las cosas, como veremos más adelante la
realidad nos demuestra lo contrario.
Como ejemplo, consideremos que deseamos guardar en un vector el DNI, nombre y
dirección de una persona. Empleando un vector con subíndice entero la solución sería:
<?php
$registro[]="20456322";
$registro[]="Martinez Pablo";
$registro[]="Colon 134";
?>
De esta forma debemos recordar que cuando deseamos mostrar el nombre de la persona
debemos acceder al subíndice 1. Esto es sencillo si tenemos un vector con tres elementos, pero
que sucede si debemos almacenar 20 datos relacionados en un vector?
Ahora vemos que para imprimir el nombre de la persona no debemos recordar una posición
dentro de un vector sino un nombre de clave. Esto se hace indispensable cuando administramos
un conjunto de datos grandes.
En un vector asociativo toda componente está asociada a una clave.
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.
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$clave['ana']="abc123";
$clave['luis']="z67yui";
$clave['carlos']="sdf3sdf";
$clave['laura']="dsf3k32";
$clave['pedro']="axldds23";
?>
</body>
</html>
Funciones en PHP
La sintaxis para la definición de una función en PHP es:
function [nombre de la función]([parámetros])
{
[algoritmo]
}
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
function mensajecentrado($men)
{
echo "<table width=\"100%\" border=\"1\">";
echo "<tr><td align=\"center\">";
echo $men;
echo "</tr></td>";
echo "</table>";
}
mensajecentrado("Primer recuadro");
echo "<br>";
mensajecentrado("Segundo recuadro");
?>
</body>
</html>
Para mostrar el texto centrado en un recuadro utilizamos la marca table de HTML. Definimos las
propiedades border con 1, para que sea visible y el ancho de 100% para que ocupe todo el
navegador. La tabla tiene una fila a la que definimos con la marca tr (table row) y un solo dato en
esa fila mediante la marca td (table data).
Para que el texto dentro de la tabla salga centrado, inicializamos la propiedad align de la marca td.
Si vemos la función, notamos que lo más trabajoso es definir todas las marcas HTML para crear la
tabla. Es importante notar que en PHP para introducir las dobles comillas dentro de un string
debemos anteceder el carácter ' \'; para introducir el carácter ' \' debemos escribir \\.
Las llamadas a la función las hacemos por medio de su nombre y pasamos el único parámetro que
requiere:
mensajecentrado("Primer recuadro");
echo "<br>";
mensajecentrado("Segundo recuadro");
Las funciones nos permiten tener un programa más ordenado y facilitan la reutilización del código.
Más adelante veremos como hacer archivos con rutinas comunes a muchas páginas.
Una función puede retornar un dato, supongamos que necesitamos una función que nos retorne
el promedio de dos valores, el código sería:
<html>
<head>
<title>Problema</title>
</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 función retorna un dato debemos emplear la palabra clave return seguida del valor
que devuelve.
En la llamada a la función el valor retornado se almacena generalmente en una variable:
$p=retornarpromedio($v1,$v2);
Si queremos que retorne más de un dato debemos emplear parámetros por referencia.
Supongamos que necesitamos ahora que una función nos retorne el cuadrado y cubo de un
número:
<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>
<html>
<head>
<title>Problema</title>
</head>
<body>
<h1>Alta de Alumnos</h1>
<form action="pagina2.php" method="post">
Ingrese nombre:
<input type="text" name="nombre"><br>
Ingrese mail:
<input type="text" name="mail"><br>
Seleccione el curso:
<select name="codigocurso">
<option value="1">PHP</option>
<option value="2">ASP</option>
<option value="3">JSP</option>
</select>
<br>
<input type="submit" value="Registrar">
</form>
</body>
</html>
El formulario es bastante similar a los que venimos desarrollando en puntos anteriores, tal vez lo
distinto es cómo emplearemos el control "select" del curso a desarrollar:
<select name="codigocurso">
<option value="1">PHP</option>
<option value="2">ASP</option>
<option value="3">JSP</option>
</select>
Cada opción tiene su respectivo valor (en este caso los números 1,2 y 3) y los textos a mostrar
PHP, ASP y JSP. El dato que se envía a la otra página es el código de curso (esto debido a que
definimos la propiedad value).
Ahora veremos como realizar la registración de los datos cargados en el formulario, en la tabla
alumnos de la base de datos base1:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion=mysql_connect("localhost","root","")
or die("Problemas en la conexion");
mysql_select_db("base1",$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>
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("base1",$conexion) or
die("Problemas en la seleccion de la base de datos");
A esta función le indicamos como primer parámetro el nombre de la base de datos con la que
trabajaremos y como segundo parámetro la referencia que retornó la función mysql_connect.
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion=mysql_connect("localhost","root","")
or die("Problemas en la conexion");
mysql_select_db("base1",$conexion)
or die("Problemas en la selección de la base de datos");
while ($reg=mysql_fetch_array($registros))
{
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>";
}
mysql_close($conexion);
?>
</body>
</html>
La primer parte es similar a lo visto hasta ahora, es decir nos conectamos a la base de datos y
seleccionamos la base de datos base1.
El comando SQL que nos permite recuperar datos de tablas se llama SELECT. Indicamos los campos
a rescatar de la tabla y luego de la palabra clave from indicamos el nombre de la tabla:
$registros=mysql_query("select codigo,nombre, mail, codigocurso
from alumnos",$conexion) or
die("Problemas en el select:".mysql_error());
En caso de haber codificado incorrectamente, el comando SQL select la función mysql_query
retorna false, por lo que se ejecuta el comando siguiente al operador or, es decir la función die.
Si el comando SQL es correcto, en la variable $registros se almacena una referencia a los datos
rescatados de la tabla alumnos. Ahora debemos ir mostrando registro a registro los datos
extraídos:
while ($reg=mysql_fetch_array($registros))
Para rescatar registro a registro los datos obtenidos por el select debemos llamar a la función
mysql_fetch_array. Esta función retorna un vector asociativo con los datos del registro rescatado,
o false en caso de no haber más registros. Es decir que si retorna un registro se almacena en el
vector $reg y la condición 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 función mysql_fetch_array.
Como vemos, para rescatar cada campo accedemos mediante el vector asociativo $reg indicando
como subíndice un campo indicado en el select:$reg['codigo']
Cada vez que llamamos a la función mysql_fetch_array nos retorna el siguiente registro.
Cuando debemos mostrar el curso mediante la instrucción switch, analizamos si tiene un 1,2 ó 3 y
procedemos a mostrar el nombre del curso.
Para separar cada alumno en la página HTML disponemos la marca "<hr>"
<html>
<head>
<title>Problema</title>
</head>
<body>
<form action="pagina2.php" method="post">
Ingrese el mail del alumno a consultar:
<input type="text" name="mail">
<br>
<input type="submit" value="buscar">
</form>
</body>
</html>
Por otro lado tenemos el archivo "pagina2.php" que se encarga de buscar el mail ingresado en el
formulario:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion=mysql_connect("localhost","root","") or
die("Problemas en la conexion");
mysql_select_db("base1",$conexion) or
die("Problemas en la selección de la base de datos");
$registros=mysql_query("select codigo,nombre, codigocurso
from alumnos where mail='$_REQUEST[mail]'",
$conexion) or
die("Problemas en el select:".mysql_error());
if ($reg=mysql_fetch_array($registros))
{
echo "Nombre:".$reg['nombre']."<br>";
echo "Curso:";
switch ($reg['codigocurso']) {
case 1:echo "PHP";
break;
case 2:echo "ASP";
break;
case 3:echo "JSP";
break;
}
}
else
{
echo "No existe un alumno con ese mail.";
}
mysql_close($conexion);
?>
</body>
</html>
Lo más 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 sólo el registro que cumple con la condición
que el mail sea igual al que ingresamos.
Como sólo puede haber un registro que cumpla la condición, llamamos a la función
mysql_fetch_array en un if:
if ($reg=mysql_fetch_array($registros))
En caso de retornar un vector asociativo la condición del if se verifica como verdadera y pasa a
mostrar los datos, en caso de retornar false se ejecuta el else.
<html>
<head>
<title>Problema</title>
</head>
<body>
<form action="pagina2.php" method="post"
enctype="multipart/form-data">
Seleccione el archivo:
<input type="file" name="foto"><br>
<input type="submit" value="Enviar">
</form>
</body>
</html>
copy($_FILES['foto']['tmp_name'],$_FILES['foto']['name']);
$nom=$_FILES['foto']['name'];
echo "<img src=\"$nom\">";
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Seleccione el archivo:
</form>
</body>
</html>
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
copy($_FILES['foto']['tmp_name'],$_FILES['foto']['name']);
$nom=$_FILES['foto']['name'];
?>
</body>
</html>
Problema propuesto.
<html>
<head>
<title>Problema</title>
</head>
<body>
Seleccione el archivo 1:
Seleccione el archivo 2:
Seleccione el archivo 2:
</form>
</body>
</html>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
if ($_FILES['foto1']['tmp_name']!="")
copy($_FILES['foto1']['tmp_name'],$_FILES['foto1']['name']);
$nom=$_FILES['foto1']['name'];
if ($_FILES['foto2']['tmp_name']!="")
copy($_FILES['foto2']['tmp_name'],$_FILES['foto2']['name']);
$nom=$_FILES['foto2']['name'];
if ($_FILES['foto3']['tmp_name']!="")
copy($_FILES['foto3']['tmp_name'],$_FILES['foto3']['name']);
$nom=$_FILES['foto3']['name'];
?>
</body>
</html>