Tutorial PHP 2
Tutorial PHP 2
com/phpya/
1 - ¿Qué es PHP?
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.
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.
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.
4 - El intérprete PHP lee desde el disco el archivo pagina1.php
Actualmente XAMPP es el entorno más popular de desarrollo con PHP. Este software
contiene todo lo que necesitamos para probar en forma local en nuestro equipo los
programas que codifiquemos en PHP.
Siempre que codifiquemos y probemos los programas en PHP el programa XAMPP junto
con 'Apache' y 'MySQL' deben estar ejecutandose.
Acotaciones
Existe otro entorno popular llamado WAMPSERVER que nos instala y administra PHP,
MySQL y Apache.
Si ya lo tiene instalado y ya está habituado a trabajar con él, no es necesario que instale el
XAMPP.
En este curso suponemos que conoce los elementos principales de HTML y algún lenguaje
de programación, por lo menos un poquito (puedes iniciar los conceptos básicos de
programación en JavaYa)
Para agregar un programa PHP dentro de una página HTML debemos por un lado al crear
el archivo definirlo con extensión php (a diferencia de las páginas estáticas que tienen
extensión htm o html) y dentro del contenido de la página, encerrar el programa entre los
símbolos
El comando de PHP para imprimir dentro de la página se llama echo. Nuestro programa
"Hola Mundo" será entonces:
pagina1.php
<html>
<head></head>
<body>
<?php
echo "Hola Mundo";
?>
</body>
</html>
<html>
<head></head>
<body>
Hola Mundo</body>
</html>
Podemos utilizar como editor de texto para codificar el programa PHP el VS Code.
VS Code: Es un editor de texto que agregando extensiones podemos trabajar con PHP con
herramientas para programar y depurar programas. Es creado y mantenido por la empresa
Microsoft. Es open source y multiplataforma (Windows, Linux y Mac)
En el último año se esta convirtiendo en el editor de texto más utilizado por los
programadores profesionales de todo el mundo.
Podemos comprobar esta situación si visitamos la encuesta de desarrolladores 2019 del sitio
de stackoverflow
Le sugiero si va ha utilizar el VS Code, luego se tome su tiempo para conocer en forma más
profunda el editor VS Code mediante el tutorial VS Code Ya
Este directorio es el que el servidor web Apache tiene asignado para recuperar páginas
cuando se las solicitamos desde un navegador.
http://localhost/pagina1.php
Tenemos en el navegador el resultado de la ejecución del programa.
Como podemos ver, es muy poco útil este programita, ya que el resultado de la ejecución
de este programa PHP será siempre el mismo, es decir mostrar el texto "Hola Mundo".
Problema resuelto.
pagina1.php
<html>
<head></head>
<body>
<?php
echo "Hola Mundo";
echo "<br>";
echo "como estas?";
?>
</body>
</html>
Ejecutar ejemplo
Problema propuesto.
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo "Mi nombre es Juan.";
echo "Tengo 20 años.";
?>
</body>
Ejecutar ejemplo
Un problema sencillo que se nos puede presentar y que no se puede resolver empleando
solo HTML es que una página esté disponible sólo los 10 primeros días del mes.
Mostraremos un cartel que diga que el sitio se encuentra disponible si la fecha es menor o
igual a 10, en caso contrario mostraremos un mensaje de sitio fuera de servicio.
Para obtener la fecha del servidor web debemos llamar a la función date y requerir sólo el
día:
$dia=date("d");
A las variables en PHP se les antecede el caracter $. Si a la función date le pasamos el
string "d" retornará sólo el día (si queremos la fecha completa: $fecha=date("d/m/Y")
Para verificar si la variable $dia es menor o igual a 10, debemos emplear la instrucción if,
similar a otros lenguajes.
pagina1.php
<html>
<head></head>
<body>
<?php
$dia = date("d");
if ($dia <= 10) {
echo "sitio activo";
} else {
echo "sitio fuera de servicio";
}
?>
</body>
</html>
> Mayor
>= Mayor o igual
< Menor
<= Menor o igual
== Igual
!= Distinto
pagina1.php
<html>
<head></head>
<body>
<?php
$dia = date("d");
if ($dia <= 10) {
echo "sitio activo";
} else {
echo "sitio fuera de servicio";
}
?>
Ejecutar ejemplo
Problema propuesto.
Sabiendo que la función rand nos retorna un valor aleatorio entre un rango de dos enteros:
$num=rand(1,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.
echo $num;
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$num = rand(1, 100);
echo $num;
echo "<br>";
if ($num <= 50) {
echo "El número es menor o igual a 50.";
} else {
Ejecutar ejemplo
5 - Tipos de variables
En PHP no es necesario definir el tipo de dato que almacena antes de utilizarla, las mismas
se crean en el momento de emplearlas. Las variables se declaran cuando se le asigna un
valor, por ejemplo:
También podemos hacer notar que para disponer comentarios de línea debemos utilizar dos
caracteres //
pagina1.php
<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 un elemento HTML. Este proceso puede acortarse un poco
pero para que sea más claro inicialmente tomaremos el camino largo de hacer la impresión
de un dato con cada comando echo.
Problema resuelto.
<head></head>
<body>
<?php
$dia1 = 15;
$dia2 = 30;
echo "El valor de la primer variable es:";
echo $dia1;
echo "<br>";
echo "El valor de la segunda variable es:";
echo $dia2;
?>
</body>
Ejecutar ejemplo
Problema propuesto.
Definir una variable de cada tipo: integer, double, string y boolean. Luego imprimirlas en la
página, una por línea.
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$edad = 20;
$peso = 90.25;
$nombre = "juan";
$existe = true;
echo "Variable integer:";
Ejecutar ejemplo
6 - Variables de tipo string
$cadena1="Hola";
$cadena2="Mundo";
echo $cadena1." ".$cadena2;
Tengamos en cuenta que el comando echo de más arriba lo podemos hacer más largo de la
siguiente forma:
echo $cadena1;
echo " ";
echo $cadena2;
A medida que uno haga ejercicios podremos resumir en un solo comando echo la salida de
múltiples variables.
Cuando una cadena encerrada entre comillas dobles contiene una variable en su interior,
ésta se trata como tal, por lo tanto se utilizará su contenido para el almacenamiento:
$dia=10;
$fecha="Hoy es $dia";
echo $fecha;
Una cadena se puede definir con las comillas simples (pero es importante tener en cuenta
que no se sustituyen las variables si empleamos comillas simples):
$nombre='juan carlos';
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$cadena1 = "diego";
$cadena2 = "juan";
$cadena3 = "ana";
$todo = $cadena1 . $cadena2 . $cadena3 . "<br>";
echo $todo;
$edad1 = 24;
Ejecutar ejemplo
Problema propuesto.
Definir tres variables enteras. Luego definir un string que incorpore dichas variables y las
sustituya en tiempo de ejecución.
Recordar que una variable se sustituye cuando el string está encerrado por comillas dobles:
$precio=90;
echo "La computadora tiene un precio de $precio";
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$nota1 = 10;
$nota2 = 7;
$nota3 = 8;
echo "Juan aprobó la materia con las notas $nota1, $nota2 y $nota3";
Ejecutar ejemplo
Cuando se pretende que el programa, una vez llegado a un cierto punto, tome un camino
concreto en determinados casos y otro diferente si las condiciones de ejecución difieren, se
utiliza el conjunto de instrucciones:
if, else y elseif. La estructura base de este tipo de instrucciones es la siguiente:
if (Condición)
{
Instrucción a1;
Instrucción a2;
}
else
{
Instrucción b1;
Instrucción b2;
}
En los casos en que las condiciones sean varias, se pueden utilizar los if de un modo
denominado anidado o anillado, como se indica de la manera siguiente:
if (Condicion 1)
{
Instrucción a1;
Instrucción a2;
}
else
{
if (Condicion 2)
{
Instrucción b1;
Instrucción b2;
}
else
{
Instrucción c1;
Instrucción c2;
}
}
if (Condicion 1)
{
Instrucción a1;
Instrucción a2;
}
elseif (Condicion 2)
{
Instrucción b1;
Instrucción b2;
}
else
{
Instrucción c1;
Instrucción c2;
}
Para las condiciones tener en cuenta que disponemos de los siguientes operadores:
<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>
$valor=rand(1,10);
En el primer problema tenemos solo dos caminos posibles, el valor es menor o igual a cinco
o es mayor.En un segundo ejemplo mostraremos como disponer una estructura condicional
if anidada.
Como podemos observar estamos en presencia de un problema que tiene tres caminos
posibles. El valor puede tener 1 dígito, 2 dígitos o 3 dígitos. Si pensamos un poco podremos
identificar que para que tenga un dígito debe generarse un valor entre 1 y 9, para que tenga
dos dígitos deberá estar comprendido entre 10 y 99, y finalmente para tener 3 dígitos deberá
ser el valor 100.
<head>
<title>Problema</title>
</head>
<body>
<?php
$valor = rand(1, 100);
echo "El valor sorteado es $valor<br>";
if ($valor <= 9) {
echo "Tiene un dígito";
} else {
if ($valor < 100) {
echo "Tiene 2 dígitos";
} else {
echo "Tiene 3 dígitos";
}
}
?>
</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 condición del primer if se verifica falsa se ejecuta el bloque del else del
primer if, la misma contiene una estructura if con sus bloques del verdadero y falso.
<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 dígito";
} elseif ($valor < 100) {
echo "Tiene 2 dígitos";
} else {
echo "Tiene 3 dígitos";
}
?>
</body>
</html>
Si uno tiene mucha práctica con otros lenguajes de programación 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 resuelto.
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
//Generar un valor aleatorio entre 1 y 100. Luego mostrar
//si tiene 1,2 o 3 dígitos.
Ejecutar ejemplo
Problema propuesto.
Para ver si una variable es igual a cierto valor debemos plantear una condición similar a:
if ($valor==3)
{
//algoritmo
}
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
Ejecutar ejemplo
Estructura for:
El primer ejemplo que haremos es mostrar en la página los números del 1 al 100:
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
for ($f = 1; $f <= 100; $f++) {
echo $f;
echo "<br>";
}
?>
</body>
</html>
El primer argumento del for es la inicialización de una variable, en este caso se inicializa la
variable $f con el valor 1. Este primer argumento del for se ejecuta solo una vez. Luego se
ejecuta el segundo argumento que es la condición. Si la misma se verifica como verdadera
se ejecuta todo el bloque comprendido entre las llaves de apertura y cerrado. Luego de
haberse ejecutado el bloque repetitivo se ejecuta el tercer argumento del for que es el
incremento de la variable, en este caso $f++ incrementa el contenido de la variable $f en 1
(también podemos poner en lugar de $f++ la asignación $f=$f+1)
Luego del incremento de la variable se ejecuta nuevamente la condición del for (segundo
argumento), de validarse nuevamente verdadero pasa a ejecutar el bloque repetitivo.
Este ciclo se repite hasta que la condición del for se verifica falsa.
while (condición)
{
[Instrucciones];
}
Esta estructura está en casi todos los lenguajes. El bloque se repite mientras la condición
del while sea verdadera.
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
$valor finalizará la estructura repetitiva y pasará a ejecutarse la instrucción inmediatamente
siguiente a la llave de cerrado del while.
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.
Problema resuelto.
<head>
<title>Problema</title>
</head>
<body>
<?php
//Mostramos los números de los días del 1 a la fecha actual;
$dia = date("d");
$inicio = 1;
w hile ($inicio <= $dia) {
echo $inicio . "<br>";
$inicio++;
Ejecutar ejemplo
Problema propuesto.
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:
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
Ejecutar ejemplo
9 - Envío de datos de un FORMULARIO
(controles text y submit)
El proceso para el manejo de FORMULARIOS requiere generalmente dos páginas, una que
implementa el formulario y otra que procesa los datos cargados en el formulario.
pagina1.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 no hay un script en PHP, el
formulario contiene elementos HTML puros.
Este elemento 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:
La propiedad type nos permite definir el tipo de control y con la propiedad name indicamos
el nombre del control.
También utilizamos el elemento 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:
pagina2.php
<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)
Es común indicar entre comillas simples el subíndice en lugar de comillas dobles (con
comillas dobles también funciona)
echo $_REQUEST['nombre'];
Problema resuelto.
pagina1.php
<html>
<head>
<title>Formulario de entrada del dato</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Captura de datos del form</title>
</head>
<body>
<?php
echo "El nombre ingresado es:";
echo $_REQUEST['nombre'];
?>
</body>
Problema propuesto.
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo $_REQUEST['nombre'];
echo "<br>";
if ($_REQUEST['edad'] >= 18) {
echo "Es mayor de edad";
} else {
echo "No es mayor de edad";
El control HTML radio generalmente se utiliza en conjunto con otros controles radio.
Cuando agrupamos un conjunto de controles radio solo uno de ellos puede estar
seleccionado y si seleccionamos otro se desmarca el actual.
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:
pagina1.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>
<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
Para seleccionar el tipo de operación a efectuar disponemos dos controles de tipo radio:
Ahora vemos que los dos controles de tipo radio 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)
pagina2.php
<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>
$_REQUEST['radio1']
$_REQUEST['valor1']
$_REQUEST['valor2']
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;
}
}
Problema resuelto.
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<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'];
Problema propuesto.
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 y 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.
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo $_REQUEST['nombre'];
echo "<br>";
if ($_REQUEST['radio1'] == "sin") {
echo "Sin estudios.";
}
if ($_REQUEST['radio1'] == "primario") {
Para analizar este control utilizaremos prácticamente el mismo ejemplo que con el objeto
radio:
Implementar un formulario que solicite la carga de dos enteros, uno en cada text.
Disponer dos controles de tipo checkbox que nos permitan seleccionar si queremos sumar
y/o restar los valores ingresados.
pagina1.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>
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
if (isset($_REQUEST['check1'])) {
$suma = $_REQUEST['valor1'] + $_REQUEST['valor2'];
echo "La suma es:" . $suma . "<br>";
}
if (isset($_REQUEST['check2'])) {
$resta = $_REQUEST['valor1'] - $_REQUEST['valor2'];
echo "La resta es:" . $resta;
}
?>
</body>
</html>
Disponemos dos if a la misma altura ya que los dos controles de tipo checkbox podrían
estar seleccionados.
Problema resuelto.
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
if (isset($_REQUEST['check1'])) {
$suma = $_REQUEST['valor1'] + $_REQUEST['valor2'];
echo "La suma es:" . $suma . "<br>";
}
if (isset($_REQUEST['check2'])) {
$resta = $_REQUEST['valor1'] - $_REQUEST['valor2'];
Problema propuesto.
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 página que procesa el formulario la cantidad de deportes que practica.
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$cant = 0;
if (isset($_REQUEST['check1'])) {
$cant++;
}
if (isset($_REQUEST['check2'])) {
Veamos ahora como podemos rescatar desde PHP el elemento seleccionado de un control
HTML de tipo select.
Implementar un formulario que solicite la carga de dos enteros, uno en cada "text".
Disponer un control de tipo select que nos permita seleccionar si queremos sumar o restar
los dos valores ingresados:
pagina1.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>
<select name="operacion">
<option value="suma">sumar</option>
<option value="resta">restar</option>
</select>
Cada opción tiene un valor (value). 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.
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
if ($_REQUEST['operacion'] == "suma") {
$suma = $_REQUEST['valor1'] + $_REQUEST['valor2'];
echo "La suma es:" . $suma;
} else {
if ($_REQUEST['operacion'] == "resta") {
$resta = $_REQUEST['valor1'] - $_REQUEST['valor2'];
echo "La resta es:" . $resta;
}
}
?>
</body>
</html>
if ($_REQUEST['operacion'] == "suma") {
$suma = $_REQUEST['valor1'] + $_REQUEST['valor2'];
echo "La suma es:" . $suma;
} else {
if ($_REQUEST['operacion'] == "resta") {
$resta = $_REQUEST['valor1'] - $_REQUEST['valor2'];
echo "La resta es:" . $resta;
}
}
Sólo se puede seleccionar un elemento de un control select (más adelante veremos como
seleccionar varios elementos en forma simultáneo)
Problema resuelto.
<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">
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
if ($_REQUEST['operacion'] == "suma") {
$suma = $_REQUEST['valor1'] + $_REQUEST['valor2'];
echo "La suma es:" . $suma;
} else {
if ($_REQUEST['operacion'] == "resta") {
$resta = $_REQUEST['valor1'] - $_REQUEST['valor2'];
echo "La resta es:" . $resta;
Problema propuesto.
Confeccionar un formulario que solicite el ingreso del nombre de una persona y un control
select (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)
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo $_REQUEST['nombre'];
if ($_REQUEST['ingresos'] == 3) {
echo " debe pagar impuestos.";
} else {
echo " no debe pagar impuestos a las ganancias.";
}
El control HTML "textarea" se diferencia del "text" en que permite el ingreso de muchas
líneas.
Problema
Implementar un formulario web para ingresar el nombre de una persona en un control text y
mediante un control de tipo textarea se permita el ingreso del curriculum de dicha persona.
pagina1.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>
<textarea name="curriculum"></textarea>
La página PHP que procesa los dos datos ingresados en el formulario es:
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo "El nombre ingresado:" . $_REQUEST['nombre'];
echo "<br>";
echo "El curriculum:" . $_REQUEST['curriculum'];
?>
</body>
</html>
El dato ingresado en el textarea se rescata en forma idéntica que los controles text, es decir
mediante el vector asociativo $_REQUEST:
echo "El curriculum:" . $_REQUEST['curriculum'];
Problema resuelto.
pagina1.php
<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>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo "El nombre ingresado:" . $_REQUEST['nombre'];
echo "<br>";
echo "El curriculum:" . $_REQUEST['curriculum'];
?>
</body>
</html>
Problema propuesto.
Confeccionar una página que muestre un contrato dentro de un textarea, disponer puntos
suspensivos donde el operador debe ingresar un texto. La página que procesa el formulario
sólo debe mostrar el contrato con las modificaciones que hizo el operador.
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<form action="pagina2.php" method="post">
Completar contrato:<br>
<textarea name="contrato" row s="8" cols="80">
En la ciudad de [........], se acuerda entre la Empresa [..........] representada por el Sr. [..............] en su carácter de A
</textarea>
<br>
<input type="submit" value="Confirmar">
</form>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
echo $_REQUEST['contrato'];
?>
</body>
14 - 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)
$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.
El vector, como podemos ver, puede ir creciendo en forma dinámica, es decir que si ahora
hacemos:
$dias[2]=31;
$dias[]=31;
$dias[]=28;
$dias[]=31;
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$nombres[] = "juan";
$nombres[] = "pedro";
$nombres[] = "ana";
for ($f = 0; $f < count($nombres); $f++) {
echo $nombres[$f];
echo "<br>";
}
?>
</body>
</html>
$edades=array("menores","jovenes","adultos");
Acotaciones
Cuando tenemos que recorrer en forma completa un vector en PHP es muy común utilizar
la estructura 'foreach'. Veamos el mismo ejemplo anterior para recorrer el vector $nombres:
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$nombres[] = "juan";
$nombres[] = "pedro";
$nombres[] = "ana";
foreach ($nombres as $nombre) {
echo $nombre;
echo "<br>";
}
?>
</body>
</html>
En cada repetición del 'foreach' la variable $nombre almacena una componente del vector
$nombres, luego dentro del 'foreach' mostramos el contenido de la variable $nombre:
Problema resuelto.
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$nombres[] = "juan";
$nombres[] = "pedro";
$nombres[] = "ana";
for ($f = 0; $f < count($nombres); $f++) {
echo $nombres[$f];
echo "<br>";
Ejecutar ejemplo
Problema propuesto.
Definir un vector con los nombres de los días de la semana. Luego imprimir el primero y el
último elemento del vector.
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$diaSemana[] = "Lunes";
$diaSemana[] = "Martes";
$diaSemana[] = "Miércoles";
$diaSemana[] = "Jueves";
$diaSemana[] = "Viernes";
$diaSemana[] = "Sábado";
Ejecutar ejemplo
Una actividad fundamental es poder registrar información en el servidor (no como hemos
estado haciendo hasta el momento generando sólo una página con los datos cargados)
En este apartado veremos como crear un archivo de texto y añadir datos al mismo.
Para resolver este problema plantearemos dos páginas, un formulario para realizar la carga
del nombre del visitante y sus comentarios (disponemos un objeto de tipo "text" y otro de
tipo "textarea"):
pagina1.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:
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>
Como en este problema nos interesa que el archivo vaya creciendo con los datos que
aportan los visitantes al sitio lo abrimos para añadir, parámetro "a".
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.
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. Si nos dirigimos a la carpeta c:\xampp\htdocs
encontraremos el archivo "datos.txt", tenga en cuenta que está en la máquina donde se
ejecutó el script de PHP (normalmente en un servidor web). 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)
Problema resuelto.
<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" row s="10" cols="40"></textarea>
<br>
Ejecutar ejemplo
pagina2.php
<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, "--------------------------------------------------------");
Problema propuesto.
Confeccionar un programa en PHP que permita hacer el pedido de pizzas via internet.
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
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<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:");
16 - Lectura de un archivo de texto.
Para la lectura de un archivo de texto contamos con la función fgets. Además debemos abrir
el archivo para lectura.
$ar=fopen("datos.txt","r") or
die("No se pudo abrir el archivo");
Para leer:
$linea=fgets($ar);
Veamos como mostrar por pantalla el contenido del archivo "datos.txt" creado en el punto
anterior:
pagina1.php
<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>
El segundo parámetro de fopen es "r" es decir read (apertura para lectura), si el archivo no
existe por ejemplo se ejecuta la función die que finaliza el programa mostrando el string
correspondiente.
La función feof retorna true si se ha llegado al final del archivo en caso contrario retorna
false. Para que se impriman todas las líneas del archivo se plantea una estructura repetitiva
que se ejecuta mientras no se llegue al final de archivo (el operador lógico not en PHP es el
caracter !):
while (!feof($ar)) {
Dentro de la estructura repetitiva leemos una línea completa del archivo de texto con la
función fgets:
$linea = fgets($ar);
La variable $linea contiene una línea completa del archivo de texto, inclusive el salto de
línea (\n)
Como el navegador no hace un salto de línea con este caracter, debemos convertir dicho
caracter al elemento <br> propia de HTML. La función que realiza esta actividad se llama
nl2br (new line to br)
$lineasalto = nl2br($linea);
echo $lineasalto;
Problema resuelto.
<head>
<title>Problema</title>
</head>
<body>
<?php
$ar = fopen("datos.txt", "r") or
die("No se pudo abrir el archivo");
w hile (!feof($ar)) {
$linea = fgets($ar);
$lineasalto = nl2br($linea);
echo $lineasalto;
}
Ejecutar ejemplo
Problema propuesto.
Confeccionar un programa que muestre el archivo de pedido de pizzas via internet del
punto anterior.
Recordemos que creamos el archivo de texto llamado pedidos.txt (grabar la página php en
el mismo directorio donde se encuentra el archivo pedidos.txt)
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$ar = fopen("pedidos.txt", "r") or
die("No se pudo abrir el archivo");
w hile (!feof($ar)) {
$linea = fgets($ar);
$lineasalto = nl2br($linea);
echo $lineasalto;
Ejecutar ejemplo
17 - 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.
<?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.
<?php
$registro['dni'] = "20456322";
$registro['nombre'] = "Martinez Pablo";
$registro['direccion'] = "Colon 134";
echo $registro['nombre'];
?>
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.
<?php
$registro = array(
'dni' => '20456322',
'nombre' => 'Martinez Pablo',
'direccion' => 'Colon 134'
);
echo $registro['dni'];
?>
Acotaciones
Cuando tenemos que recorrer en forma completa un vector asociativo en PHP podemos
utilizar la estructura 'foreach'. Veamos un ejemplo:
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$articulo = array(
'codigo' => 1,
'descripcion' => 'manzanas',
'precio' => 30.25
);
</body>
</html>
En cada repetición del 'foreach' la variable $clave almacena el subíndice del vector y la
variable $valor contiene el valor de la componente del vector:
pagina1.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>
Ingrese tercer valor:
<input type="text" name="valor3">
<br>
Ingrese cuarto valor:
<input type="text" name="valor4">
<br>
Ingrese quinto valor:
<input type="text" name="valor5">
<br>
<input type="submit">
</form>
</body>
</html>
Es importante notar que al input de tipo 'submit' no le definimos la propiedad 'name', con el
objetivo que no se cargue en el vector asociativo '$_REQUEST'.
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$suma = 0;
foreach ($_REQUEST as $clave => $valor) {
echo "Valor: " . $valor;
echo "<br>";
$suma = $suma + $valor;
}
echo "La suma es: " . $suma;
?>
</body>
</html>
Como vemos podemos recorrer en forma completa los 5 elementos del vector
'$_REQUEST' y acceder tanto a su valor como su clave:
$suma = 0;
foreach ($_REQUEST as $clave => $valor) {
echo "Valor: " . $valor;
echo "<br>";
$suma = $suma + $valor;
}
Si solo queremos acceder a los valores del vector asociativo y no a sus claves, luego
podemos codificar la sintaxis del foreach:
Problema resuelto.
<head>
<title>Problema</title>
</head>
<body>
<?php
//Almacenar en un vector asociativo la cantidad de dias que tiene
//cada mes del año. Luego accederlo por su nombre como subindice.
$mes['enero'] = 31;
$mes['febrero'] = 29;
$mes['marzo'] = 31;
$mes['abril'] = 30;
Ejecutar ejemplo
Problema propuesto.
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.
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$clave['ana'] = "abc123";
$clave['luis'] = "z67yui";
$clave['carlos'] = "sdf3sdf";
$clave['laura'] = "dsf3k32";
$clave['pedro'] = "axldds23";
Ejecutar ejemplo
18 - Funciones en PHP
La sintaxis para la definición de una función en PHP es:
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
function mostrartitulo($men)
{
echo "<h1 style=\"text-align:center\">";
echo $men;
echo "</h1>";
}
mostrartitulo("Primer titulo");
echo "<br>";
mostrartitulo("Segundo segundo");
?>
</body>
</html>
Si vemos la función, notamos que lo más trabajoso es definir todos los elementos HTML
para crear el titulo. 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 dos barras \\.
Las llamadas a la función las hacemos por medio de su nombre y pasamos el único
parámetro que requiere:
mostrartitulo("Primer titulo");
echo "<br>";
mostrartitulo("Segundo segundo");
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.
$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>
Problema resuelto.
<head>
<title>Problema</title>
</head>
<body>
<?php
function mostrartitulo($men)
{
echo "<h1 style=\"text-align:center\">";
echo $men;
echo "</h1>";
}
Ejecutar ejemplo
Problema propuesto.
Confeccionar un formulario que solicite la carga del nombre de usuario y su clave en dos
oportunidades. En la página que se procesan los datos del formulario implementar una
función que imprima un mensaje si las dos claves ingresadas son distintas.
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
Uno de los empleos principales de PHP es el acceso a una base de datos en el servidor. Las
operaciones básicas se hacen empleando como lenguaje el SQL.
PHP implementa distintas funciones según la base de datos a emplear. Existen funciones
actualmente para acceder a las siguientes servidores de bases de datos:
- MySQL
- MariaDB
- Microsoft SQL Server
- Oracle
- PostgreSQL
- SysBase
- FrontBase
- Informix
- InterBase
- Ingres
- mSQL
- dBase
- SQLlite
Para crear una base de datos el XAMPP instala también un programa codificado en PHP
que nos permite interactuar con el MySQL o MariaDB.
Este programa se llama PHPMyAdmin (como veremos nos permite crear las bases de datos,
tablas, índices, usuarios etc.)
Como podemos ver la interfaz del PHPMyAdmin es un programa que se ejecuta en la web:
Para crear una base de datos procedemos a seleccionar la pestaña "Base de datos" e
ingresamos como nombre "base1" y presionamos el botón crear:
Luego de crear la base de datos podemos ver que aparece en el lado izquierdo:
En el lado derecho de la pantalla podemos ahora ingresar el nombre de una tabla y la
cantidad de campos que tendrá (crearemos una tabla llamada alumnos con 4 campos):
En el PHPMyAdmin ingresamos:
Es importante también hacer notar que en el campo codigo debemos marcar en Indice el
valor "primary" y tildar la columna A_I (Auto_Increment):
Por último presionamos el botón guardar y ya tenemos la tabla "alumnos" creada en la base
de datos "base1":
La tabla almacenará datos de alumnos que desarrollarán cursos de programación en PHP,
ASP y JSP.
En los próximos conceptos comenzaremos a ver como desde PHP podemos comunicarnos
con la base de datos "base1" y acceder a la tabla "alumnos" para ejecutar los comandos
SQL más comunes como pueden ser: select, insert, delete, update etc.
20 - INSERT (Alta de registros en una
tabla)
Luego de crear una base de datos y sus tablas (Vamos a trabajar con la base de datos ya
creada: base1, que contiene la tabla alumnos), veremos como agregar registros.
Necesitamos dos páginas para este proceso, una será el formulario de carga de datos y la
siguiente será la que efectúe la inserción en la tabla.
pagina1.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).
pagina2.php
<html>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion = mysqli_connect("localhost", "root", "", "base1") or
die("Problemas con la conexión");
('$_REQUEST[nombre]','$_REQUEST[mail]',$_REQUEST[codigocurso])")
or die("Problemas en el select" . mysqli_error($conexion));
mysqli_close($conexion);
</html>
('$_REQUEST[nombre]','$_REQUEST[mail]',$_REQUEST[codigocurso])")
or die("Problemas en el select" . mysqli_error($conexion));
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 subíndices 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 la función mysqli_query, por lo que se
ejecuta la instrucción posterior al or, es decir la función die que mostrará el error generado
por MySql llamando a la función mysqli_error.
Por último cerramos la conexión con la base de datos y mostramos un mensaje indicando
que la carga se efectuó en forma correcta.
<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">
Ejecutar ejemplo
pagina2.php
<html>
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion = mysqli_connect("localhost", "root", "", "base1") or
die("Problemas con la conexión");
Problema propuesto.
Crear en la base de datos "base1" otra tabla llamada "cursos".
La estructura de esta segunda tabla debe ser:
codigo int auto_increment primery_key
nombrecurso varchar(40)
Utilizar el PHPMyAdmin para la creación de esta tabla.
Implementar las dos páginas necesarias para efectuar el alta de cursos. Un formulario para
ingresar el nombre del curso y otra página donde se efectuará el insert.
Solución
pagina1.php
<html>
<head>
<title>Problema</title>
</head>
<body>
Ejecutar ejemplo
pagina2.php
<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion = mysqli_connect("localhost", "root", "", "base1") or
die("Problemas con la conexión");
mysqli_close($conexion);