Diferencia entre revisiones de «Usuario:ManuelRomero/php/vectores»

De WikiEducator
Saltar a: navegación, buscar
(Los modos de pasar los valores)
 
(25 revisiones intermedias por el mismo usuario no mostrado)
Línea 4: Línea 4:
  
 
<!--__NOEDITSECTION__-->
 
<!--__NOEDITSECTION__-->
 +
 
{|cellpadding="5" cellspacing="6" style="width:100%;background:#DFFFFF; border-style:solid; border-width:2px; border-color:#0066FF;"  
 
{|cellpadding="5" cellspacing="6" style="width:100%;background:#DFFFFF; border-style:solid; border-width:2px; border-color:#0066FF;"  
 
| width="100%" valign="top" style="padding: 0; margin:0px;" |
 
| width="100%" valign="top" style="padding: 0; margin:0px;" |
Línea 12: Línea 13:
 
[[Imagen:DWES_TituloTema3.gif|center]]
 
[[Imagen:DWES_TituloTema3.gif|center]]
 
|}
 
|}
 
+
__NOTOC__
  
 
===Arrays===
 
===Arrays===
Un tipo de datos compuesto es aquel que te permite almacenar más de un valor. En PHP puedes utilizar dos tipos de datos compuestos: el array y el objeto. Los objetos los veremos más adelante; vamos a empezar con los arrays.
+
*Un tipo de datos compuesto es aquel que te permite almacenar más de un valor.  
 
+
*En PHP puedes utilizar dos tipos de datos compuestos: el array y el objeto.  
Un array es un tipo de datos que nos permite almacenar varios valores. Cada miembro del array se almacena en una posición a la que se hace referencia utilizando un valor clave. Las claves pueden ser numéricas o asociativas.
+
*Los objetos los veremos más adelante.
  
 +
*Un array es un tipo de datos que nos permite almacenar varios valores.
 +
*Cada miembro del array se almacena en una posición a la que se hace referencia utilizando un valor clave.
 +
*Las claves pueden ser numéricas o asociativas.
 +
<source lang=php>
 
// array numérico
 
// array numérico
 
$modulos1 = array(0 => "Programación", 1 => "Bases de datos", ..., 9 => "Desarrollo web en entorno servidor");
 
$modulos1 = array(0 => "Programación", 1 => "Bases de datos", ..., 9 => "Desarrollo web en entorno servidor");
 
// array asociativo
 
// array asociativo
 
$modulos2 = array("PR" => "Programación", "BD" => "Bases de datos", ..., "DWES" => "Desarrollo web en entorno servidor");  
 
$modulos2 = array("PR" => "Programación", "BD" => "Bases de datos", ..., "DWES" => "Desarrollo web en entorno servidor");  
Icono de iDevice Debes conocer
+
</source>
En PHP existe la función print_r, que nos muestra todo el contenido del array que le pasamos. Es muy útil para tareas de depuración.
+
;Tipos de array:
 +
:En función de su clave pueden ser indexados (clave numérica) o asociativos (Clave con valor)
 +
:En los arrays numéricos empezamos por 0
 +
:En funcion del tipo de índices que tenga rpuede ser unidimensional o multidimensional
 +
===Crear un array===
 +
*Podemos usar el operador array();
 +
<source lang=php>
 +
$capitales = array();
 +
$capital ["españa"=>"madrid", "italia"=>"roma","Alemania"=>"Berlin"];
 +
</source>
 +
*Es lo mismo que hacer
 +
<source lang=php>
 +
$capitales = array("españa"=>"madrid", "italia"=>"roma","Alemania"=>"Berlin");
 +
$capital ["españa"=>"madrid", "italia"=>"roma","Alemania"=>"Berlin"];
 +
*También se puede crear directamente co []
 +
<source lang=php>
 +
$capitales["españa"]="madrid";
 +
$capitales[["italia"]="roma"
 +
$capitales["Alemania"]="Berlin";
 +
</source>
 +
*Existen muchas funciones asociadas a los arrays
 +
*count($array) me da el número de elementos
 +
{{Tarea|
 +
Define un array de 5 ciudades y recorrelo con un bucle for usando count()
 +
}}
 +
<source lang=php>
 +
<?php
 +
//defino e inicializo el vector
 +
$ciudades[0]="Valencia";
 +
$ciudades[]="Teruel";
 +
$ciudades[]="Burgos";
 +
$ciudades[]="Zaragoza";
 +
$ciudades[]="Huesca";
  
Función print_r
+
//Obtengo el número de elementos
 +
$num= count($ciudades);
 +
echo "hay $num ciudades";
 +
for ($n=0; $n<$num; $n++){
 +
    echo "ciudad $n es $ciudades[$n]<br>";
 +
}
 +
?>
 +
</source>
  
Para hacer referencia a los elementos almacenados en un array, tienes que utilizar el valor clave entre corchetes:
+
===Ver el contenido de un array===
 +
*Podemos usar la función ya conocida '''''var_dump()'''''
 +
*También podemos usar la fucnion print_r.
 +
===Funciones para manejar matrices===
 +
*Tamaño: count(), sizeof()
 +
*Operador +: concatena dos matrices
 +
*Recorrer una matriz next(), prev(),  reset(), current(),key(), reset()
 +
*busqueda preg_grep(), array_search(), in_array()
 +
*Ordenar sort()
 +
*Aquí  tenemos un listado de todas las funciones, hay muchas muchas http://es1.php.net/manual/en/ref.array.php
  
 +
 +
 +
*Para hacer referencia a los elementos almacenados en un array, tienes que utilizar el valor clave entre corchetes:
 +
<source lang=php>
 
$modulos1 [9]
 
$modulos1 [9]
 
$modulos2 ["DWES"]  
 
$modulos2 ["DWES"]  
Los arrays anteriores son vectores, esto es, arrays unidimensionales. En PHP puedes crear también arrays de varias dimensiones almacenando otro array en cada uno de los elementos de un array.
+
</source>
 
+
*Es interesante recordar que en PHP puedes crear también arrays de varias dimensiones almacenando otro array en cada uno de los elementos de un array.
 +
<source lang=php>
 
// array bidimensional
 
// array bidimensional
 
$ciclos = array(
 
$ciclos = array(
Línea 39: Línea 97:
 
     "DAM" => array ("PR" => "Programación", "BD" => "Bases de datos", ..., "PMDM" => "Programación multimedia y de dispositivos móviles")
 
     "DAM" => array ("PR" => "Programación", "BD" => "Bases de datos", ..., "PMDM" => "Programación multimedia y de dispositivos móviles")
 
);
 
);
Para hacer referencia a los elementos almacenados en un array multidimensional, debes indicar las claves para cada una de las dimensiones:
+
</source>
 
+
*Para hacer referencia a los elementos almacenados en un array multidimensional, debes indicar las claves para cada una de las dimensiones:
 +
<source lang=php>
 
$ciclos ["DAW"] ["DWES"]
 
$ciclos ["DAW"] ["DWES"]
En PHP no es necesario que indiques el tamaño del array antes de crearlo. Ni siquiera es necesario indicar que una variable concreta es de tipo array. Simplemente puedes comenzar a asignarle valores:
+
</source>
 
+
*En PHP no es necesario que indiques el tamaño del array antes de crearlo.
 +
*Ni siquiera es necesario indicar que una variable concreta es de tipo array.  
 +
*Como ya hemos visto, simplemente puedes comenzar a asignarle valores:
 +
<source lang=php>
 
// array numérico
 
// array numérico
 
$modulos1 [0] = "Programación";
 
$modulos1 [0] = "Programación";
Línea 54: Línea 116:
 
...
 
...
 
$modulos2 ["DWES"] = "Desarrollo web en entorno servidor";  
 
$modulos2 ["DWES"] = "Desarrollo web en entorno servidor";  
Ni siquiera es necesario que especifiques el valor de la clave. Si la omites, el array se irá llenando a partir de la última clave numérica existente, o de la posición 0 si no existe ninguna:
+
</source>
 
+
*En PHP tampoco  es necesario que especifiques el valor de la clave.  
 +
*Al omitirla  el array se irá llenando a partir de la última clave numérica existente, o de la posición 0 si no existe ninguna:
 +
<source lang=php>
 
$modulos1 [ ] = "Programación";
 
$modulos1 [ ] = "Programación";
 
$modulos1 [ ] = "Bases de datos";
 
$modulos1 [ ] = "Bases de datos";
 
...
 
...
 
$modulos1 [ ] = "Desarrollo web en entorno servidor";  
 
$modulos1 [ ] = "Desarrollo web en entorno servidor";  
 
+
</source>
 
<div class="slide">
 
<div class="slide">
  
Línea 71: Línea 135:
 
*Mostrar los resultados por pantalla.
 
*Mostrar los resultados por pantalla.
 
}}
 
}}
 +
<source lang=php>
 +
<?php
  
 +
$notas = array();
 +
$tamano = rand(1,50);
 +
//Ahora rellenamos el valor de $tamano posiciones del vector
 +
for ($n=0; $n<$tamano;$n++){
 +
    $notas[$n] = rand(1,10);
 +
}
 +
//recorremos calculando minimo, maximo y media
 +
unset($notas[5]);
 +
//El primer valor del vector inicializa las variables
 +
$min = $notas[0];
 +
$max = $notas[0];
 +
$suma = $notas[0];
 +
for ($n=1; $n<count($notas) ;$n++){
 +
    if ($min>$notas[$n])
 +
        $min=$notas[$n];
 +
    if ($max<$notas[$n])
 +
        $max=$notas[$n];
 +
    $suma+=$notas[$n];
 +
}
 +
echo "La nota máxima es $max<br>";
 +
echo "La nota mínima es $min<br>";
 +
echo "La nota media es es". ($suma/$n);
 +
 +
?>
 +
 +
</source>
 
{{Tarea|
 
{{Tarea|
 
*Implementar una función que busca si un determinado valor aparece en una matriz.  
 
*Implementar una función que busca si un determinado valor aparece en una matriz.  
Línea 84: Línea 176:
 
'''''Random Images'''''
 
'''''Random Images'''''
 
*Escribir un programa que:
 
*Escribir un programa que:
 
+
**Inicialice un vector con 10 imágenes (podéis utilizar éste [http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/crea_array.txt código.php] que crea el vector $imagenes)
;Inicialice un vector con 10 imágenes (podéis utilizar éste [http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/crea_array.txt código.php] que crea el vector $imagenes)
+
**La página debe mostrar, aleatoriamente, 3 imágenes (puedes usar como alternativa  la función shuffle ($imagenes) la cuál desordena el vector), o usar un rand para obtener indices aleatorios.
;La página debe mostrar, aleatoriamente, 3 imágenes (utilizar la función shuffle ($imagenes) la cuál desordena el vector)
+
**Cada 5 segundos ha de refrescarse la página para ir mostrando imágenes distintas (podéis usar, por  
;Cada 5 segundos ha de refrescarse la página para ir mostrando imágenes distintas (podéis usar, por  
+
 
ejemplo, este trozo de código HTML y añadirlo en el <HEAD> de la página:  
 
ejemplo, este trozo de código HTML y añadirlo en el <HEAD> de la página:  
 
<source lang=html4strict>
 
<source lang=html4strict>
Línea 93: Línea 184:
 
</html>
 
</html>
 
</source>
 
</source>
Ejemplo:
 
 
}}
 
}}
 
+
<source lang=html4strict>
 
+
<!DOCTYPE html>
 
+
<!--
 
+
To change this license header, choose License Headers in Project Properties.
 
+
To change this template file, choose Tools | Templates
 
+
and open the template in the editor.
 
+
-->
 +
<html>
 +
    <head>
 +
        <meta charset="UTF-8"/>
 +
        <meta http-equiv="refresh" content="5" url="index.php"/>
 +
        <title></title>
 +
    </head>
 +
    <body>
 +
        <?php
 +
        $imagenes = array(
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/a_piece_for_the_wicked_vol_1.jpg",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/double_t.jpg",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/flagrantly_yours.jpg",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/gothic.jpg",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/iliad_of_a_wolverhampton_wanderer.jpg",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/libertine.jpg",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/lullabies_for_tough_guys.jpg",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/nocturnal_nomad.jpg",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/the_idle_gait_of_the_self_possessed.gif",
 +
"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/the_life_and_times_of_a_ballad_monger.jpg"
 +
);
 +
        $n1=rand(0,9);
 +
        $n2=rand(0,9);
 +
        $n3=rand(0,9);
 +
        echo "<img src=$imagenes[$n1]><img src=$imagenes[$n2]><img src=$imagenes[$n3]>";
 +
        ?>
 +
    </body>
 +
</html>
 +
</source>
  
 
===Variables globales Vs superglobales===
 
===Variables globales Vs superglobales===
Línea 135: Línea 253:
 
#$_SERVER['REMOTE_ADDR']:dirección IP desde la que el usuario está viendo la página.
 
#$_SERVER['REMOTE_ADDR']:dirección IP desde la que el usuario está viendo la página.
 
#$_SERVER['REQUEST_METHOD']:método utilizado para acceder a la página ('GET', 'HEAD', 'POST' o 'PUT')
 
#$_SERVER['REQUEST_METHOD']:método utilizado para acceder a la página ('GET', 'HEAD', 'POST' o 'PUT')
{{Actividad| Haz un script que no de la información de las variables vistas anteriormente}}
+
{{Actividad| Haz un script que nos de la información de las variables vistas anteriormente}}
 +
<source lang=php>
 +
<?php
  
 +
$datos = $_SERVER;
 +
foreach ($datos as $indice => $valor){
 +
    echo ("Valor de $indice es $valor<br>");
 +
}
 +
?>
 +
</source>
  
 +
===Leer datos===
 +
*Todos los lenguajes de programación tienen primitivas o incluso instrucciones propias
 +
#Leer valores del teclado
 +
#Mostrar resultados en pantalla
 +
*En el caso de PHP, hemos visto alguna primitiva para mostrar valores por pantalla (En realidad lo que hace es escribirlas al fichero html que entrega al cliente), como son '''''echo''''' y '''''print'''''
 +
*Pero nos falta ver como podemos hacer que el cliente aporte valores al programa escribiéndolos por el teclado
 +
*Para leer datos lo hacemos mediante un  formulario (hay más métodos, como leer un fichero , ...)
 +
*El formulario será parte de la página del cliente, en él tendremos cajas de texto donde el cliente podrá escribier contenido
 +
{{image:formularo.png}}
 +
*A continuación vamos a ver de modo básico como crear formularios en el cliente y a continuación que es lo que nos interesa, como leerlos
 +
===Formulario HTML===
 +
*Etiqueta form con una serie de atributos de los que nos interesan dos principalmente
 +
#action especifica el fichero que se ejecutará cuando se envíe el formulario
 +
#method especifica el modo en el que se van a pasar los parámetros (valores introducidos a los difernetes objetos del formulario, o que tengan asignados por defecto).
 +
<source lang=html4strict>
 +
  <form action="mifichero.php" method="POST"
 +
    ......
 +
  </form>
 +
</source>
 +
*En este caso estamos indicando que cuando se envíe el formulario, se intentará ejecutar un fichero llamado '''''mifichero.php'''''. La ubiación del fichero como no se especifica se supone en el mismo sitio donde estaba el fichero que actualmente está viendo el cliente.
 +
*También se especifica que los valores enviados con el formulario irán en el cuerpo de documento usando el protocolo http, y no en el URI con el signo ? cono ocurre si se especificara GET
 +
{{Puntos clave|
 +
Tan inseguro es usar GET como POST. si queremos garantizar seguridad debemos usar https y no http}}
 +
*Por supuesto hay más atributos, el id es importante para poder acceder a ese elemento con javascript; estos son los que nosotros debemos conocer para usar
 +
*También es interesante el atributo enctype que permite usar algún tipo de cifrado para enmascarar la información que se envía, pero insisto en usar https si se quiere confidencialidad con un nivel aceptable de seguridad.
 +
====Elementos dentro del formulario====
 +
*Dentro del forumulario debemos poder recoger información que el cliente nos facilite
 +
*Al menos deberíamos de conocer dos elementos '''''input''''' y '''''button''''' o bien '''''submit'''''
 +
*El input representa una caja de texto
 +
*El submit es un botón que tiene automatizada la acción de enviar el formulario al hacer click sobre él.
 +
Es interesante ojear esta sencilla página que te informa de como hacer formularios
 +
http://www.aulaclic.es/html/t_8_1.htm
 +
*Elemento input, en él especifiaremos los siguientes atributos
 +
;type
 +
:indicaremos el tipo de elemento de entrada (text, password, email, checkbox...)
 +
:Aquí podemos ver una lista de posibles valores, tened en cuenta que con html5 se introdujeron 13 nuevos tipos.
 +
  http://www.w3schools.com/tags/att_input_type.asp
 +
...)
 +
:También es interesante el tipo hidden (especialmente usado para pasar valores del cliente al servidor de forma transparente para el usuario.
  
 +
;name
 +
:indicaremos el nombre asociado a este input.
 +
:Con este identificador podremos en el servidor recuperar la información.
 +
;value
 +
:Es el valor que tiene el input. Si queremos que por defecto tenga un valor
 +
*Dentro del form necesitaremos al menos un input y un submit
 +
*EJ. en el emisor tenemos
  
 +
<source lang=html4strict>
 +
<!DOCTYPE html>
  
===Leer datos===
+
<html>
*Para leer datos lo hacemos de un formulario
+
    <head>
*el formulario lo envía el cliente
+
        <title>Tabla de multiplaicar</title>
*Obligatoriamente necesitamos el atributo name de la etiqueta input
+
    </head>
*EJ. en el emisor tenemos
+
    <body>
Dime un número:
+
        <form action="tabla.php" method="GET">
<FORM ACTION="tabla.php" METHOD="GET">
+
            Inserta un numero <br>
<INPUT TYPE="text" NAME="numero"><BR>
+
            <input type="text" name="numero"/>
<INPUT TYPE="submit" VALUE="Enviar">  
+
            <br/>
</div>
+
            <input TYPE="submit" VALUE="Enviar"/>  
Al presionar el botón de enviar se envía la página al servidor
+
        </form>
La página que especificamos en el botón action la gestiona ''tabla.php'' en este caso
+
    </body>
En el servidor para recuperar el valor utilizaremos la tabla supergobal
+
</html>
una tabla es una estructura indexada por índices
+
</source>
leeremos el índice nombre de variable de la tabla  
+
*Y obtenemos la siguiente imagen
$_GET o $_POST dependiendo de el método de envío
+
[[imagen:formulario.png]]
 +
#Al presionar el botón de enviar se envía la página al servidor
 +
#La página que especificamos en el botón action la gestiona ''tabla.php'' en este caso
 +
#En el servidor para recuperar el valor utilizaremos la tabla supergobal
 +
#una tabla es una estructura indexada por índices
 +
#leeremos el índice nombre de variable de la tabla  
 +
#$_GET o $_POST dependiendo de el método de envío
 +
<source lang=php>
 
  Valor numérico introducido: <?php echo $_GET['numero'] ?>
 
  Valor numérico introducido: <?php echo $_GET['numero'] ?>
 +
</source>
 +
===Los modos de pasar los valores===
 +
*Usaremos dos métodos para pasar valores
 +
#GET Pasamos los valores en la propia URI seguido del caracter '''''?''''' y separando parejas '''''variable=valor''''' por ''''';'''''
 +
#POST Enviándolo en el cuerpo del forumulario usando el protocolo hppt
 +
*Cómo leer los datos en el servidor
 +
*Accediendo a la variable superglobal $_POST y $_GET.
 +
*Son arrays asociativos. La clave es el nombre de la variable. en el caso anterior para leer el valor de numero
 +
<source lang=php>
 +
<?php
 +
$numero = $_POST['numero'];
 +
.....
 +
</source>
 +
*Observe que usarmeos $_POST y $_GET en función de como hemos pasado los parámetros
 +
*Si no estamos muy seguros también se puede usar $_REQUEST
 +
 +
{{Tarea|
 +
*Hacemos un formulario que envíe datos de nombre, apellido e idiomas que habla entre inglés, alemán, rumano y español
 +
*En el servidor simplemente visualizaremos los datos introducidos
 +
*Observa la forma de especificar un checkbox y de enviarlo
 +
<source lang=html4strict>
 +
.....
 +
<input type="checkbox" name="idiomas[]" value="ingles" /> Idioma ingles americano<br />
 +
<input type="checkbox" name="idiomas[]" value="frances" /> Idioma frances<br>
 +
....
 +
</source>
 +
}}
 +
 +
*En el cliente
 +
<source lang=html4strict>
 +
<!DOCTYPE html>
 +
<html>
 +
    <head>
 +
        <title>Datos personales</title>
 +
        <meta charset="UTF-8">
 +
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
 +
    </head>
 +
    <body>
 +
        <form action="procesa.php" method="POST">
 +
            Inserta un numero <br>
 +
            nombre
 +
            <input type="text" name="nombre"/>
 +
            Apellido
 +
            <input type="text" name="apellido"/>
 +
            <br>
 +
            <!--
 +
              observar que los diferentes opciones van un un mismo array
 +
            -->
 +
            <input type="checkbox" name="idiomas[]" value="ingles" />Idioma ingles americano<br/>
 +
            <input type="checkbox" name="idiomas[]" value="frances" />Idioma frances<br/>
 +
            <input type="checkbox" name="idiomas[]" value="ingles" />Idioma aleman<br/>
 +
            <input type="checkbox" name="idiomas[]" value="frances" />Idioma rumano<br/>
 +
           
 +
            <input TYPE="submit" VALUE="Enviar"/>
 +
        </form>
 +
       
 +
    </body>
 +
</html>
 +
</source>
 +
*En el servidor
 +
<source lang=php>
 +
<?php
 +
 +
/*
 +
* To change this license header, choose License Headers in Project Properties.
 +
* To change this template file, choose Tools | Templates
 +
* and open the template in the editor.
 +
*/
 +
 +
// Leemos los datos del formulario0
 +
echo "hola1" ;
 +
$nombre = $_POST('nombre');
 +
echo "hola2";
 +
$apellido = $_POST['apellido'];
 +
$idiomas = $_POST['idiomas'];
 +
echo "hola3";
 +
echo "nombre : $nombre apellidos : $apellido<br/>";
 +
echo "idiomas que habla :<br/>";
 +
foreach ($idiomas as $idioma){
 +
    echo "$idioma<br/>";
 +
}
 +
?>
 +
</source>
 +
{{Tarea|
 +
*Modifica el programa de validación de fecha, pero que la introduzca el usuario
 +
*Al final se visualizará la fecha de la siguiente manera
 +
día XX del mes de XX(En letra] del año [xxxx]
 +
}}
 +
 +
===Verificar datos en el servidor===
 +
*Independientemente de las verificaciones que se hagan en el cliente, siempre hay que verificar datos en el servidor
 +
*Esta cuestión cobra especial importancias si se trabaja con bases de datos, volveremos a la cuestión en el tema de bases de datos
 +
*Por ejemplo se puede querer verificar que se hayan insertado datos '''''isset(....)'''''
 +
{{Tarea|Vamos a leer los datos de la página anterior verificando que el usuario haya insertado la fecha, si no damos un mensaje}}
 +
 +
{{Tarea|
 +
Realizar un programa php con las siguientes especificaciones
 +
Se realizará en un único fichero php
 +
El programa nos pedirá que nos validemos, con los siguientes requisitos
 +
Si es la primera vez que nos conectamos, aparecer un formulario que nos pedirá usuario y pass
 +
Si le damos aceptar se verificará lo siguiente
 +
#que los campos de usuario y pass no estén vacíos
 +
#el el usuario tenga al menos 6 caracteres
 +
#que el pass contenga al menos un dígito
 +
Si una vez validado todo está ok se visualizará los datos de usuario y pass que se introdujeron
 +
Si se incumple algo de lo anterior, se mostrará un mensaje de error y el formulario aparecer sin datos
 +
}}
 +
*Para este ejercicio se puede mirar la función preg_match http://php.net/manual/es/function.preg-match.php. NO USAR ereg() está en desuso.
 +
*Para el tema de expresiones regulares hay mucha documentación por ejemplo http://informaticapc.com/tutorial-php/expresiones-regulares-buscar.php
 +
en este caso el patrón es muy sencillo $patron='/[0-9]/'
 +
*Para ver el códgio http://pastebin.com/print.php?i=UanhmPLi
 +
<source lang=php>
 +
<!DOCTYPE html>
 +
-
 +
 +
 +
 +
 +
<html>
 +
    <head>
 +
        <title>Formulario </title>
 +
        <meta charset="UTF-8">
 +
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
 +
    </head>
 +
    <body>
 +
        <!-- Aqui empieza el código php -->
 +
        <?php
 +
        //Si es la primera vez que se ejecuta el formulario
 +
        if (!(isset($_POST['enviar']))){
 +
            //Primera vez
 +
            $usuario="";
 +
            $pass="";
 +
           
 +
        }
 +
       
 +
        else{
 +
            if (errores()){
 +
                //Segunda o siguientes veces con erro
 +
            $usuario="";
 +
            $pass="";
 +
               
 +
            }else{
 +
               
 +
                //Todo ok
 +
                $usuario=$_POST['usuario'];
 +
                $pass=$_POST['pass'];
 +
 +
            }
 +
        }
 +
        function errores(){
 +
            $usuario = $_POST['usuario'];
 +
            $pass = $_POST['pass'];
 +
            if ((empty($usuario))||(empty($pass))){
 +
                echo "Los campos de usuariio y pass no pueden estar vacíos";
 +
                return true;
 +
            }
 +
            if (strlen($usuario)<=7){
 +
                echo "La cadena de usuario debe tener más de 7 caracteres y no ".strlen($us
 +
                return true;
 +
            }
 +
            $expresion='/[0-9]/';
 +
            if (preg_match($expresion,$pass)!=true){
 +
                echo "La pass debe tener al menos un dígito y no lo tienen ".($pass);
 +
                return true;
 +
               
 +
            }
 +
            return false;
 +
        }
 +
        ?>
 +
        if
 +
        <form action=<?php echo $_SERVER['PHP_SELF'] ?> method="POST">
 +
            Inserta un numero <br>
 +
            usuario : <input type="text" name="usuario" value="<?php echo "$usuario"; ?>"/>
 +
            Pass:    <input type="text" name="pass" value="<?php echo "$pass" ;?>"/>
 +
            <br>
 +
            <input type="submit" value="Enviar" name="enviar"/>
 +
        </form>
 +
       
 +
    </body>
 +
</html>
 +
 +
</source>
 +
 +
 +
 
|}
 
|}

Última revisión de 10:15 22 oct 2014




DWES TituloTema3.gif


Arrays

  • Un tipo de datos compuesto es aquel que te permite almacenar más de un valor.
  • En PHP puedes utilizar dos tipos de datos compuestos: el array y el objeto.
  • Los objetos los veremos más adelante.
  • Un array es un tipo de datos que nos permite almacenar varios valores.
  • Cada miembro del array se almacena en una posición a la que se hace referencia utilizando un valor clave.
  • Las claves pueden ser numéricas o asociativas.
// array numérico
$modulos1 = array(0 => "Programación", 1 => "Bases de datos", ..., 9 => "Desarrollo web en entorno servidor");
// array asociativo
$modulos2 = array("PR" => "Programación", "BD" => "Bases de datos", ..., "DWES" => "Desarrollo web en entorno servidor");
Tipos de array
En función de su clave pueden ser indexados (clave numérica) o asociativos (Clave con valor)
En los arrays numéricos empezamos por 0
En funcion del tipo de índices que tenga rpuede ser unidimensional o multidimensional

Crear un array

  • Podemos usar el operador array();
$capitales = array();
$capital ["españa"=>"madrid", "italia"=>"roma","Alemania"=>"Berlin"];
  • Es lo mismo que hacer
$capitales = array("españa"=>"madrid", "italia"=>"roma","Alemania"=>"Berlin");
$capital ["españa"=>"madrid", "italia"=>"roma","Alemania"=>"Berlin"];
*También se puede crear directamente co []
<source lang=php>
$capitales["españa"]="madrid";
$capitales[["italia"]="roma"
$capitales["Alemania"]="Berlin";
  • Existen muchas funciones asociadas a los arrays
  • count($array) me da el número de elementos


Icon assess.gif

Tarea

Define un array de 5 ciudades y recorrelo con un bucle for usando count()




<?php
//defino e inicializo el vector
$ciudades[0]="Valencia";
$ciudades[]="Teruel";
$ciudades[]="Burgos";
$ciudades[]="Zaragoza";
$ciudades[]="Huesca";
 
//Obtengo el número de elementos
$num= count($ciudades);
echo "hay $num ciudades";
for ($n=0; $n<$num; $n++){
    echo "ciudad $n es $ciudades[$n]<br>";
}
?>

Ver el contenido de un array

  • Podemos usar la función ya conocida var_dump()
  • También podemos usar la fucnion print_r.

Funciones para manejar matrices

  • Tamaño: count(), sizeof()
  • Operador +: concatena dos matrices
  • Recorrer una matriz next(), prev(), reset(), current(),key(), reset()
  • busqueda preg_grep(), array_search(), in_array()
  • Ordenar sort()
  • Aquí tenemos un listado de todas las funciones, hay muchas muchas http://es1.php.net/manual/en/ref.array.php


  • Para hacer referencia a los elementos almacenados en un array, tienes que utilizar el valor clave entre corchetes:
$modulos1 [9]
$modulos2 ["DWES"]
  • Es interesante recordar que en PHP puedes crear también arrays de varias dimensiones almacenando otro array en cada uno de los elementos de un array.
// array bidimensional
$ciclos = array(
     "DAW" => array ("PR" => "Programación", "BD" => "Bases de datos", ..., "DWES" => "Desarrollo web en entorno servidor"),
     "DAM" => array ("PR" => "Programación", "BD" => "Bases de datos", ..., "PMDM" => "Programación multimedia y de dispositivos móviles")
);
  • Para hacer referencia a los elementos almacenados en un array multidimensional, debes indicar las claves para cada una de las dimensiones:
$ciclos ["DAW"] ["DWES"]
  • En PHP no es necesario que indiques el tamaño del array antes de crearlo.
  • Ni siquiera es necesario indicar que una variable concreta es de tipo array.
  • Como ya hemos visto, simplemente puedes comenzar a asignarle valores:
// array numérico
$modulos1 [0] = "Programación";
$modulos1 [1] = "Bases de datos";
...
$modulos1 [9] = "Desarrollo web en entorno servidor";
// array asociativo
$modulos2 ["PR"] = "Programación";
$modulos2 ["BD"] = "Bases de datos";
...
$modulos2 ["DWES"] = "Desarrollo web en entorno servidor";
  • En PHP tampoco es necesario que especifiques el valor de la clave.
  • Al omitirla el array se irá llenando a partir de la última clave numérica existente, o de la posición 0 si no existe ninguna:
$modulos1 [ ] = "Programación";
$modulos1 [ ] = "Bases de datos";
...
$modulos1 [ ] = "Desarrollo web en entorno servidor";




Icon assess.gif

Tarea

  • Generar un array de 10 posiciones de valores enteros entre 1 y 100.
  • Recorrer el array, guardando el valor m�ximo y m�nimo y obtener la media
  • Mostrar los resultados por pantalla.




<?php
 
$notas = array();
$tamano = rand(1,50);
//Ahora rellenamos el valor de $tamano posiciones del vector
for ($n=0; $n<$tamano;$n++){
    $notas[$n] = rand(1,10);
}
//recorremos calculando minimo, maximo y media
unset($notas[5]);
//El primer valor del vector inicializa las variables
$min = $notas[0];
$max = $notas[0];
$suma = $notas[0];
for ($n=1; $n<count($notas) ;$n++){
    if ($min>$notas[$n])
        $min=$notas[$n];
    if ($max<$notas[$n])
        $max=$notas[$n];
    $suma+=$notas[$n];
}
echo "La nota máxima es $max<br>";
echo "La nota mínima es $min<br>";
echo "La nota media es es". ($suma/$n);
 
?>


Icon assess.gif

Tarea

  • Implementar una función que busca si un determinado valor aparece en una matriz.
  • La función recibe 2 parámetros: la matriz y el elemento a buscar, y devuelve si ha encontrado el valor (TRUE) o no (FALSE).
  1. Implementar la función, con los parámetros (el array, y el valor a buscar).
  2. Para probar la función implementada, generar un array de 100 posiciones de valores enteros entre 1 y 100. #Generar, también, el número que hay que buscar en el array.
  3. Llamar a la función con el array y el valor como parámetros de la función.
  4. Mostrar los resultados por pantalla.






Icon assess.gif

Tarea

Random Images

  • Escribir un programa que:
    • Inicialice un vector con 10 imágenes (podéis utilizar éste código.php que crea el vector $imagenes)
    • La página debe mostrar, aleatoriamente, 3 imágenes (puedes usar como alternativa la función shuffle ($imagenes) la cuál desordena el vector), o usar un rand para obtener indices aleatorios.
    • Cada 5 segundos ha de refrescarse la página para ir mostrando imágenes distintas (podéis usar, por

ejemplo, este trozo de código HTML y añadirlo en el <HEAD> de la página:

<META HTTP-EQUIV=Refresh CONTENT="5; URL=vuestra_pagina.php">
</html>




<!DOCTYPE html>
<!--
To change this license header, choose License Headers in Project Properties.
To change this template file, choose Tools | Templates
and open the template in the editor.
-->
<html>
    <head>
        <meta charset="UTF-8"/>
        <meta http-equiv="refresh" content="5" url="index.php"/>
        <title></title>
    </head>
    <body>
        <?php
        $imagenes = array(
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/a_piece_for_the_wicked_vol_1.jpg",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/double_t.jpg",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/flagrantly_yours.jpg",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/gothic.jpg",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/iliad_of_a_wolverhampton_wanderer.jpg",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/libertine.jpg",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/lullabies_for_tough_guys.jpg",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/nocturnal_nomad.jpg",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/the_idle_gait_of_the_self_possessed.gif",
		"http://www.tecn.upf.es/~ocelma/cpom/practicas/php/random_images/discography/the_life_and_times_of_a_ballad_monger.jpg"
		);
        $n1=rand(0,9);
        $n2=rand(0,9);
        $n3=rand(0,9);
        echo "<img src=$imagenes[$n1]><img src=$imagenes[$n2]><img src=$imagenes[$n3]>";
        ?>
    </body>
</html>

Variables globales Vs superglobales

  • Ya hemos visto como en php una variable tiene el ámbito en el cual es accesible y visible
  • Las variables son locales a la función en la cual aparecen, si queremos acceder dentro de una función a una variable del script y actuar sobre su valor, debemos hacerla global.
  • PHP Dispone un un importante conjunto de variables superglobales.
  • El desarrollador tiene acceso a dichas variables en cualquier momento del script.
  • El sistema se encarga de tenerlas actualizadas, con el valor correspondiente
  • PHP incluye unas Son variables internas predefinidas que pueden usarse desde cualquier ámbito, por lo que reciben el nombre de variables superglobales.
  • No es necesario que uses global para acceder a ellas.
  • Cada una de estas variables es un array que contiene un conjunto de valores
  • Posteriormente veremos cómo se utilizan los arrays).
  • Aquí puedes acceder a las variables superglobales disponibles en PHP se pueden ver son las siguientes:
  • Son las siguientes
  1. $GLOBALS Hace referencia a todas las variables disponibles en el ámbito global
  2. $_SERVER Información del entorno del servidor y de ejecución
  3. $_GET Variables HTTP GET
  4. $_POST Variables HTTP POST
  5. $_FILES Variables de Carga de Archivos HTTP
  6. $_COOKIE Cookies HTTP
  7. $_SESSION Variables de sesión
  8. $_REQUEST Variables HTTP REQUEST. Un array asociativo que por defecto contiene el contenido de $_GET, $_POST y $_COOKIE.
  9. $_ENV
  • Analizaremos una de ellas
$_SERVER.
Contiene información sobre el entorno del servidor web y de ejecución. Entre la información que nos ofrece esta variable, tenemos:
Principales valores de la variable $_SERVER
  1. $_SERVER['PHP_SELF']: script que se está ejecutando actualmente.
  2. $_SERVER['SERVER_ADDR']: dirección IP del servidor web.
  3. $_SERVER['SERVER_NAME']: nombre del servidor web.
  4. $_SERVER['DOCUMENT_ROOT']: directorio raíz bajo el que se ejecuta el guión actual.
  5. $_SERVER['REMOTE_ADDR']:dirección IP desde la que el usuario está viendo la página.
  6. $_SERVER['REQUEST_METHOD']:método utilizado para acceder a la página ('GET', 'HEAD', 'POST' o 'PUT')


Icon activity.jpg

Actividad

Haz un script que nos de la información de las variables vistas anteriormente



<?php
 
$datos = $_SERVER;
foreach ($datos as $indice => $valor){
    echo ("Valor de $indice es $valor<br>");
}
?>

Leer datos

  • Todos los lenguajes de programación tienen primitivas o incluso instrucciones propias
  1. Leer valores del teclado
  2. Mostrar resultados en pantalla
  • En el caso de PHP, hemos visto alguna primitiva para mostrar valores por pantalla (En realidad lo que hace es escribirlas al fichero html que entrega al cliente), como son echo y print
  • Pero nos falta ver como podemos hacer que el cliente aporte valores al programa escribiéndolos por el teclado
  • Para leer datos lo hacemos mediante un formulario (hay más métodos, como leer un fichero , ...)
  • El formulario será parte de la página del cliente, en él tendremos cajas de texto donde el cliente podrá escribier contenido

Archivo:Formularo.png

  • A continuación vamos a ver de modo básico como crear formularios en el cliente y a continuación que es lo que nos interesa, como leerlos

Formulario HTML

  • Etiqueta form con una serie de atributos de los que nos interesan dos principalmente
  1. action especifica el fichero que se ejecutará cuando se envíe el formulario
  2. method especifica el modo en el que se van a pasar los parámetros (valores introducidos a los difernetes objetos del formulario, o que tengan asignados por defecto).
   <form action="mifichero.php" method="POST"
    ......
   </form>
  • En este caso estamos indicando que cuando se envíe el formulario, se intentará ejecutar un fichero llamado mifichero.php. La ubiación del fichero como no se especifica se supone en el mismo sitio donde estaba el fichero que actualmente está viendo el cliente.
  • También se especifica que los valores enviados con el formulario irán en el cuerpo de documento usando el protocolo http, y no en el URI con el signo ? cono ocurre si se especificara GET


Icon key points.gif

Puntos clave

Tan inseguro es usar GET como POST. si queremos garantizar seguridad debemos usar https y no http


  • Por supuesto hay más atributos, el id es importante para poder acceder a ese elemento con javascript; estos son los que nosotros debemos conocer para usar
  • También es interesante el atributo enctype que permite usar algún tipo de cifrado para enmascarar la información que se envía, pero insisto en usar https si se quiere confidencialidad con un nivel aceptable de seguridad.

Elementos dentro del formulario

  • Dentro del forumulario debemos poder recoger información que el cliente nos facilite
  • Al menos deberíamos de conocer dos elementos input y button o bien submit
  • El input representa una caja de texto
  • El submit es un botón que tiene automatizada la acción de enviar el formulario al hacer click sobre él.

Es interesante ojear esta sencilla página que te informa de como hacer formularios

http://www.aulaclic.es/html/t_8_1.htm
  • Elemento input, en él especifiaremos los siguientes atributos
type
indicaremos el tipo de elemento de entrada (text, password, email, checkbox...)
Aquí podemos ver una lista de posibles valores, tened en cuenta que con html5 se introdujeron 13 nuevos tipos.
 http://www.w3schools.com/tags/att_input_type.asp
...)
También es interesante el tipo hidden (especialmente usado para pasar valores del cliente al servidor de forma transparente para el usuario.
name
indicaremos el nombre asociado a este input.
Con este identificador podremos en el servidor recuperar la información.
value
Es el valor que tiene el input. Si queremos que por defecto tenga un valor
  • Dentro del form necesitaremos al menos un input y un submit
  • EJ. en el emisor tenemos
<!DOCTYPE html>
 
<html>
    <head>
        <title>Tabla de multiplaicar</title>
    </head>
    <body>
        <form action="tabla.php" method="GET">
            Inserta un numero <br>
            <input type="text" name="numero"/>
            <br/>
            <input TYPE="submit" VALUE="Enviar"/> 
        </form>
    </body>
</html>
  • Y obtenemos la siguiente imagen

Formulario.png

  1. Al presionar el botón de enviar se envía la página al servidor
  2. La página que especificamos en el botón action la gestiona tabla.php en este caso
  3. En el servidor para recuperar el valor utilizaremos la tabla supergobal
  4. una tabla es una estructura indexada por índices
  5. leeremos el índice nombre de variable de la tabla
  6. $_GET o $_POST dependiendo de el método de envío
 Valor numérico introducido: <?php echo $_GET['numero'] ?>

Los modos de pasar los valores

  • Usaremos dos métodos para pasar valores
  1. GET Pasamos los valores en la propia URI seguido del caracter ? y separando parejas variable=valor por ;
  2. POST Enviándolo en el cuerpo del forumulario usando el protocolo hppt
  • Cómo leer los datos en el servidor
  • Accediendo a la variable superglobal $_POST y $_GET.
  • Son arrays asociativos. La clave es el nombre de la variable. en el caso anterior para leer el valor de numero
<?php
$numero = $_POST['numero'];
.....
  • Observe que usarmeos $_POST y $_GET en función de como hemos pasado los parámetros
  • Si no estamos muy seguros también se puede usar $_REQUEST



Icon assess.gif

Tarea

  • Hacemos un formulario que envíe datos de nombre, apellido e idiomas que habla entre inglés, alemán, rumano y español
  • En el servidor simplemente visualizaremos los datos introducidos
  • Observa la forma de especificar un checkbox y de enviarlo
.....
<input type="checkbox" name="idiomas[]" value="ingles" /> Idioma ingles americano<br />
<input type="checkbox" name="idiomas[]" value="frances" /> Idioma frances<br>
....





  • En el cliente
<!DOCTYPE html>
<html>
    <head>
        <title>Datos personales</title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
    </head>
    <body>
         <form action="procesa.php" method="POST">
            Inserta un numero <br>
            nombre
            <input type="text" name="nombre"/>
            Apellido
            <input type="text" name="apellido"/>
            <br>
            <!--
              observar que los diferentes opciones van un un mismo array
            -->
            <input type="checkbox" name="idiomas[]" value="ingles" />Idioma ingles americano<br/>
            <input type="checkbox" name="idiomas[]" value="frances" />Idioma frances<br/>
            <input type="checkbox" name="idiomas[]" value="ingles" />Idioma aleman<br/>
            <input type="checkbox" name="idiomas[]" value="frances" />Idioma rumano<br/>
 
            <input TYPE="submit" VALUE="Enviar"/> 
        </form>
 
    </body>
</html>
  • En el servidor
<?php
 
/* 
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
 
// Leemos los datos del formulario0
echo "hola1" ;
$nombre = $_POST('nombre');
echo "hola2";
$apellido = $_POST['apellido'];
$idiomas = $_POST['idiomas'];
echo "hola3";
echo "nombre : $nombre apellidos : $apellido<br/>";
echo "idiomas que habla :<br/>";
foreach ($idiomas as $idioma){
    echo "$idioma<br/>";
}
?>


Icon assess.gif

Tarea

  • Modifica el programa de validación de fecha, pero que la introduzca el usuario
  • Al final se visualizará la fecha de la siguiente manera
día XX del mes de XX(En letra] del año [xxxx]





Verificar datos en el servidor

  • Independientemente de las verificaciones que se hagan en el cliente, siempre hay que verificar datos en el servidor
  • Esta cuestión cobra especial importancias si se trabaja con bases de datos, volveremos a la cuestión en el tema de bases de datos
  • Por ejemplo se puede querer verificar que se hayan insertado datos isset(....)


Icon assess.gif

Tarea

Vamos a leer los datos de la página anterior verificando que el usuario haya insertado la fecha, si no damos un mensaje





Icon assess.gif

Tarea

Realizar un programa php con las siguientes especificaciones Se realizará en un único fichero php El programa nos pedirá que nos validemos, con los siguientes requisitos Si es la primera vez que nos conectamos, aparecer un formulario que nos pedirá usuario y pass Si le damos aceptar se verificará lo siguiente

  1. que los campos de usuario y pass no estén vacíos
  2. el el usuario tenga al menos 6 caracteres
  3. que el pass contenga al menos un dígito

Si una vez validado todo está ok se visualizará los datos de usuario y pass que se introdujeron Si se incumple algo de lo anterior, se mostrará un mensaje de error y el formulario aparecer sin datos




en este caso el patrón es muy sencillo $patron='/[0-9]/'

<!DOCTYPE html>
-
 
 
 
 
<html>
    <head>
        <title>Formulario </title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
    </head>
    <body>
        <!-- Aqui empieza el código php -->
        <?php 
        //Si es la primera vez que se ejecuta el formulario
        if (!(isset($_POST['enviar']))){
            //Primera vez
            $usuario="";
            $pass="";
 
        }
 
        else{
            if (errores()){
                //Segunda o siguientes veces con erro
            $usuario="";
            $pass="";
 
            }else{
 
                //Todo ok
                 $usuario=$_POST['usuario'];
                 $pass=$_POST['pass'];
 
            }
        }
        function errores(){
            $usuario = $_POST['usuario'];
            $pass = $_POST['pass'];
            if ((empty($usuario))||(empty($pass))){
                echo "Los campos de usuariio y pass no pueden estar vacíos";
                return true;
            }
            if (strlen($usuario)<=7){
                echo "La cadena de usuario debe tener más de 7 caracteres y no ".strlen($us
                return true;
            }
            $expresion='/[0-9]/';
            if (preg_match($expresion,$pass)!=true){
                echo "La pass debe tener al menos un dígito y no lo tienen ".($pass);
                return true;
 
            }
            return false;
        }
        ?>
        if 
         <form action=<?php echo $_SERVER['PHP_SELF'] ?> method="POST">
            Inserta un numero <br>
            usuario : <input type="text" name="usuario" value="<?php echo "$usuario"; ?>"/>
            Pass:    <input type="text" name="pass" value="<?php echo "$pass" ;?>"/>
            <br>
            <input type="submit" value="Enviar" name="enviar"/> 
        </form>
 
    </body>
</html>


Obtenido de «https://es.wikieducator.org/index.php?title=Usuario:ManuelRomero/php/vectores&oldid=15898»