Autenticación en php con MySql y POO


Autenticación en una pagina web es el proceso de confirmar que un usuario es quien dice ser, asi de simple.

En el siguiente tutorial construiremos un sistema sencillo de autenticación utilizando php, mysql, html, y sesiones utilizando POO

Necesitamos

  • Conocimientos básicos de PHP, MySQL
  • Un servidor web (appserv, xamp, etc)
  • Un Editor de Texto, el notepad++ te sirve, si tienes otro mucho mejor, yo utilizare phpDesigner

Nivel: Novatos

Duración: 15 Minutos

Comencemos.

1. Lo primero que necesitamos es una base de datos, crea uno en mysql, para este ejemplo la base de datos se llama “tuto_slogin”, a esta db debes añadir una tabla y tambien algunos datos, la estructura es la siguiente:

CREATE TABLE slogin_usuario (
  `user` varchar(60) NOT NULL,
  pass varchar(12) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

INSERT INTO slogin_usuario VALUES ('jaimito', '123456');

2. Necesitamos establecer una estructura de carpetas para nuestro proyecto, usamos la siguiente:

proyecto php

Estructura proyecto en phpDesigner

3. En la carpeta PHP crearemos dos clases:

mysql.class.php

<?php
# CLASE PARA GESTIONAR LA BASE DE DATOS
class mysql
{
#____________________________________________________________________________soy_una_barra_separadora :)  
    private $localhost = "localhost";    
    private $usuario = "USUARIO";
    private $password = "CONTRASEÑA MYSQL";
    private $database = "tuto_slogin"; 
#____________________________________________________________________________soy_una_barra_separadora :)  
    /* METODO PARA CONECTAR CON LA BASE DE DATOS*/
 public function conectar()
 {
  if(!isset($this->conexion)){
    $this->conexion = (mysql_connect($this->localhost, $this->usuario,$this->password)) or die(mysql_error() );
    mysql_select_db($this->database , $this->conexion) or die(mysql_error());      
  }
 }     
#____________________________________________________________________________soy_una_barra_separadora :)  
 // METODO PARA REALIZAR UNA CONSULTA 
 // INPUT: $q -> consulta
 // OUTPUT: $result
 public function consulta($q)
 {
    $resultado = mysql_query($q,$this->conexion);
    if(!$resultado){
     echo 'MySQL Error: ' . mysql_error();
     exit;
    }
    return $resultado; 
 }
#____________________________________________________________________________soy_una_barra_separadora :) 
 // METODO PARA CONTAR EL NUMERO DE FILAS DEVUELTAS
 // INPUT: $r
 // OUTPUT: numero de filas 
 function numero_de_filas($result){
  if(!is_resource($result)) 
            return false;
  return mysql_num_rows($result);
 }
#____________________________________________________________________________soy_una_barra_separadora :)  
}
?>

usuario.class.php

<?php
# CLASE USUARIO PARA GESTIONAR A LOS USUARIOS DEL SISTEMA

require_once 'mysql.class.php';

class usuario extends mysql
{
#____________________________________________________________________________soy_una_barra_separadora :) 
  #Cuando se crea el objeto se realiza la conexion a la base de datos 
  public function __construct()
  {
    $this->conectar();    
  }
#____________________________________________________________________________soy_una_barra_separadora :) 
  public function validar_ingreso($usuario=NULL,$password=NULL)
  {
    if( $usuario!=null and $password!=null)
    {
        # se limpian variables
        $usuario = htmlspecialchars(trim($usuario), ENT_QUOTES);        
        $password = htmlspecialchars(trim($password), ENT_QUOTES);
        # se realiza la consulta a la base de datos
        $r = $this->consulta("SELECT * FROM slogin_usuario WHERE user='$usuario' AND pass='$password' ");
        # retorna resultado en boolean
        return ( $this->numero_de_filas($r)>0) ? true : false ;          
    }
    else
        return false;    
  }  
#____________________________________________________________________________soy_una_barra_separadora :)  
}
?>

Las clases estan comentadas
4. Ahora en el archivo “index.php” colocaremos el formulario de autenticación y tambien un poco de codigo php:

<?php
  session_start();
    if( $_POST )
 {
     #Comprueba que las variables existan
     if ( isset( $_POST['usuario'] ) and isset( $_POST['password'] ) ){
            # archivo php necesario
   require_once 'php/usuario.class.php';
            # instancia a clase usuario
            $usuario = new usuario();
       if( $usuario->validar_ingreso($_POST['usuario'] , $_POST['password']) ){
                //crea instancia de sesion segura
                $_SESSION["usuario"]=$_POST['usuario'];//variable de sesion;
                # si usuario existe -> redireccionar a nueva pagina 
                echo 'Exito: Usuario '.$_SESSION["usuario"].' logueado';exit;
            }else
              echo 'Error: Acceso Denegado';     
   }
  }        
?>

<form id="form" name="form" method="post" action="">
<span>Nombre de Usuario</span>
<br />
<input id="usuario" name="usuario" type="text" value="" />
<br />
<span>Contraseña</span>
<br />
<input id="password" name="password" type="password" value="" />
<br />
<input name="enviar" id="enviar" type="submit" value="Entrar" />
</form>

Visualmente en el navegador debes tener esto:

formulario

Eso es todo, prueba desde el navegador para ver que no existan fallas.

¿Te gusto el post? Comparte con tus amigos...



Comentarios
  1. Jose Clemente Pulido Rodriguez dice:

    Disculpa al momento de que quiero generar mi aplicacion.exe de java me sale un pequeño error al inciar mi programa en .exe muestra que no contiene el classpath org.gjt.mm.mysql.Driver. hice de todo pero no encuentro solucion ojala y me pudieras ayudar con este error.

    Gracias!.

  2. Jesusisimo dice:

    eres muy buen programador hermano segui con tus ejemplos que ayudas a mas de uno en lo que hacen , bueno solo te doy las gracias

  3. Jean Carlos Espinoza dice:

    Vieras que adapte tu codigo en Java Postgresql y en una tabla que tiene 2000000 de registro e pagina bien de 10000 y 10000 registros solo cuando lo corro desde el netbeans pero cuando hago ele ejecutable del sistema ya no funciona que puede ser.

    • Mouse dice:

      si corre desde netbeans imposible que no corra cuando crear el jar, debe ser algún problema de configuración si fuera de código te avisaría, pero podes hacer prueba de escritorio para ver donde esta el problema, testea si se conecta, si realiza la consulta sin problemas, la memoria tambien es importante, 10000 registros cargarlos en gui es pesado :)

      saludos

  4. Henry dice:

    hola, hago todos los pasos pero me sale Error: No existe archivo prueba.mdb no se que falta me podes ayudar, mi base de datos en acces se llama prueba y esta en el mismo directorio que el php, y no se que falta, pero da error, ah y tambien una consulta da los mimo si se hace en servidor linux que windows? xq mi proveedor de hosting lo tengo en linux, mil gracias.

  5. christian fernando ortega dice:

    cordial saludo

    estoy haciendo una aplicación en java y me gustaría saber como le podría poner una herramienta de selección de texto al jasperviewer

    quisiera poder copiar el contenido del reporte

    grcias

Deja un comentario

Nombre (obligatorio)

Email (obligatorio)

Website


6 + = doce

Freelancer
  • Ultimas entradas

  • Categorias