Diferencia entre revisiones de «Usuario:ManuelRomero/php/smarty/login1»
De WikiEducator
< Usuario:ManuelRomero | php
(→La lógica) |
|||
(4 revisiones intermedias por el mismo usuario no mostrado) | |||
Línea 11: | Línea 11: | ||
#Al darle a validar, se validará el usuario contra la base de datos. | #Al darle a validar, se validará el usuario contra la base de datos. | ||
#Si no es ok mostrará un error y seguiremos en '''''login.php''''', si es correcto iremos a '''''productos.php''''' | #Si no es ok mostrará un error y seguiremos en '''''login.php''''', si es correcto iremos a '''''productos.php''''' | ||
− | Para este escenario necesitaremos los siguientes ficheros según vemos en la imagen | + | *Para este escenario necesitaremos los siguientes ficheros según vemos en la imagen |
+ | |||
+ | [[Archivo:TiendaLoginWeb.png]]<br /> | ||
+ | |||
− | |||
;Descripción de la imagen | ;Descripción de la imagen | ||
Línea 25: | Línea 27: | ||
#login.php (lógica) | #login.php (lógica) | ||
#productos.php (lógica sin contenido) | #productos.php (lógica sin contenido) | ||
− | #login.tpl ( | + | #login.tpl (presentación). |
===Desarrollando el código=== | ===Desarrollando el código=== | ||
Línea 47: | Línea 49: | ||
private static $conexion; | private static $conexion; | ||
+ | |||
+ | |||
+ | |||
+ | |||
/*======================conectar()====================================== | /*======================conectar()====================================== | ||
conecta con la base de datos, usando PDO | conecta con la base de datos, usando PDO | ||
Línea 53: | Línea 59: | ||
****************************************************************************************** */ | ****************************************************************************************** */ | ||
private static function conectar(){ | private static function conectar(){ | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
Línea 77: | Línea 71: | ||
* ***********************************************************************************************/ | * ***********************************************************************************************/ | ||
protected static function ejecutaConsulta($sql,$valores) { | protected static function ejecutaConsulta($sql,$valores) { | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
Línea 100: | Línea 83: | ||
* ***********************************************************************************************/ | * ***********************************************************************************************/ | ||
public static function verificaCliente($nombre, $pass) { | public static function verificaCliente($nombre, $pass) { | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
}//End de la clase DB.php | }//End de la clase DB.php | ||
Línea 125: | Línea 97: | ||
<source lang=php> | <source lang=php> | ||
<?php | <?php | ||
− | |||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
?> | ?> | ||
</source> | </source> | ||
Línea 200: | Línea 144: | ||
<source lang=php> | <source lang=php> | ||
<?php | <?php | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
?> | ?> | ||
</source> | </source> | ||
Línea 241: | Línea 169: | ||
</source> | </source> | ||
*Este código puede verse funcionado | *Este código puede verse funcionado | ||
− | http:// | + | http://manuel.infenlaces.com/dwes/tienda/TiendaProductos/login.php |
Última revisión de 21:42 18 abr 2019
La lógica
- Generaremos el fichero login.php
- Su función es autentificar al usuario de la aplicación web.
- Todos los usuarios de la aplicación deberán autentificarse utilizando esta página antes de poder acceder al resto de páginas.
- La siguiente imagen muestra un caso de uso de este escenario
- Descripcion de la imagen
- Login pedirá un usuario y contraseña para validar
- Al darle a validar, se validará el usuario contra la base de datos.
- Si no es ok mostrará un error y seguiremos en login.php, si es correcto iremos a productos.php
- Para este escenario necesitaremos los siguientes ficheros según vemos en la imagen
- Descripción de la imagen
- El cliente invoca al fichero login.php
- Este método solicitará usuario y contraseña visualizando la plantilla login.tpl
- Cuando presionemos enviar validará contra la base de datos
- Si todo ok, mostrará la plantilla productos.tpl;
- Si no se ha validado, mostrará la plantilla login.tpl con el error encontrado
- Para implementar esta parte del proyecto necesitaremos desarrollar los siguientes ficheros
- DB.php (clase)
- login.php (lógica)
- productos.php (lógica sin contenido)
- login.tpl (presentación).
Desarrollando el código
- DB.php
- Esta es una clase que mantendrá todo el acceso a la base de datos
- De momento solo necesito un método de validar el usuario
- Este método tendrá que hacer 3 cosas:
- conectar a la base de datos,
- realizar una consulta,
- verificar que la consulta contenga un registro (OK! Usuario existe), o no (Usuario no registrado)
- Seguramente otros métodos tengan que hacer estas acciones (conectar, ejecutar consultas, …), por lo que estas acciones será métodos privados de la clase.
- Para poder pasar parámetros a la hora de ejecutar la consutla usaremos PDO en lugar de mysqli
- El código de esta clase
<?php class DB { //atributo privado de conexión private static $conexion; /*======================conectar()====================================== conecta con la base de datos, usando PDO da valor al atributo privado y estático $conexion de la clase En caso de no conectarse aborta la app y muestra un mensaje ****************************************************************************************** */ private static function conectar(){ } /*======================ejecutaConsulta ($sql,$valores)====================================== Accion: Ejecuta una consulta preparada con los valores de los parámetros de la consulta preparada Parámetros: $sql es la consulta preparada y parametrizada $valores es un array asociativo con los valores de los distintos parámetros de la consulta anterior Retorna =La consulta despues de ejecutarla, o null si no la ha podido ejecutaqr en caso de no ejecutarla da un mensaje * ***********************************************************************************************/ protected static function ejecutaConsulta($sql,$valores) { } /*======================verificaCliente ($nombre,$pass)====================================== Accion: verifica si un nombre y pass son contenidos en la base de datos Parámetros: $nombre es el nombre de usuario $pass es la password para ese nombre Retorna true o false según se haya podido o no validar * Recordar que la pass está cifrada con md5 en la base de datos * ***********************************************************************************************/ public static function verificaCliente($nombre, $pass) { } }//End de la clase DB.php ?>
- login.php
- Este fichero implementa las acciones especificadas anteriormente
- Cargamos la librería de smarty
- Realizamos la lógica
- Exportamos la variable $error para la plantilla
- Visualizamos la plantilla
- El código se exporta a continaución
<?php ?>
- login.tpl
- La plantilla tiene la parte de html
- Lo único que visualiza es el código de error en caso de que lo hubiera
<!DOCTYPE html> {*Plantilla para login. Es invocada desde login.php. solo visualiza el $error del php*} <html> <head> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <title>Login Tienda Web con Plantillas</title> <link href="tienda.css" rel="stylesheet" type="text/css"> </head> <body> <div id='login'> <form action='login.php' method='post'> <fieldset > <legend>Login</legend> {*si la variable error tiene algún valor se visualiza*} <div><span class='error'>{$error}</span></div> <div class='campo'> <label for='usuario' >Usuario:</label><br/> <input type='text' name='usuario' id='usuario' maxlength="50" /><br/> </div> <div class='campo'> <label for='password' >Contraseña:</label><br/> <input type='password' name='password' id='password' maxlength="50" /><br/> </div> <div class='campo'> <input type='submit' name='enviar' value='Enviar' /> </div> </fieldset> </form> </div> </body> </html>
- productos.php
- En esta primera parte del proyecto estos ficheros solo contienen información básica,
- Se implementará en la segunda parte del desarrollo
<?php ?>
- producto.tpl
- La plantilla del producto
- Simplemente una página de información de lo que hará
<!DOCTYPE html> {*Platilla para visualizar los productos, se invoca desde productos.php*} <html> <head> <title>práctica de tienda página de productos </title> <meta charset="UTF-8"> </head> <body> {*primero solo visualizaremos que el usuario está conectado*} <h1>Bienvenido a esta página {$usuario}</h1> <hr/> <h3>En breve visualizará una lista de productos para hacer su compra</h3> </body> </html>
- Este código puede verse funcionado
http://manuel.infenlaces.com/dwes/tienda/TiendaProductos/login.php