66 comentarios en “Login y registro PDO PHP y MySQL: Ejemplo completo”

  1. Hola, creo q no me van a responder porque esta pagina fue publicada hace tres anyos. Al crear una cuenta, me lleva a una pagina en blanco y cuando me voy al login me dice que la cuenta no ha sido activada, necesito ayuda por favor

  2. Es la tercera vez que quiero publicar para que me ayude, ya que no envia el correo para confirmación. Si ya no reciben preguntas al menos informe. Lo tengo de prueba en un servidor pago pero no me envia el correo como comente anteriomente. Espero respuesta. Gracias

  3. Hola. Estoy probando este ingreso y login, pero al momento de ejecutarlo me sale el error:

    SQLSTATE[23000]: Integrity constraint violation: 1048 Column ‘clave’ cannot be null
    La verdad que no encuentro donde esta el error.
    Si puede ayudarme

  4. Hola. Te comento que el sistema me funciona perfectamente como está, con la tabla correspondiente, pero al momento de adaptarlo para lo que necesito hacer. He modificado el codigo para que reconozca la otra base y los campos que quiero que registre, pero no lo hace y tampoco me sale un error en pantalla. Necesito ayuda. Desde ya gracias y felicitaciones.

  5. me marca error en la lineá 31
    Warning: password_hash() expects parameter 2 to be long, string given in C:\xampp\htdocs\login-y-registro-pdo-php-y-mysql-ejemplo-completo\classes\password.php on line 31

    SQLSTATE[23000]: Integrity constraint violation: 1048 Column ‘password’ cannot be null

    esos son los errores que marcar ala hora de registrarme y poner mi contraseña

    1. Manuel, espero que BAULCODE nos de la respuesta. Te cuento que anule todo lo que comprende de esa linea 31 y graba en la base de datos. Lo que no consigo es que me envie el correo. Hasta me gustaria que no haga todo ese movimiento, o sea directamente crear el usuario.

  6. Hola!!!, gracias por tu trabajo, me sirvió de base para el sistema que estoy desarrollando,
    Estos cambios hicieron que funcionara bien sobre PHP 7.4.4 y SQLSERVER, detallo la página y como se modifico la linea con cambios.

    Saludos, y gracias nuevamente.

    config.php
    //$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, true);

    index.php
    $hashedpassword = password_hash($_POST[‘password’], PASSWORD_DEFAULT);
    $id = $db->lastInsertId();

    user.php
    $stmt = $this->_db->prepare(«SELECT password, username, memberID FROM members WHERE username = :username AND active=’Yes'»);

  7. Hola Administrador de Baulcode:

    Ante todo agradecer por el trabajo publicado ya que es bastante difícil encontrar un ejemplo tan completo utilizando PDO en PHP, yo e adaptado el sistema de login a las necesidades de mi página web y funciona correcto, SALVO por un error que me aparece en el entorno de producción que me indica que no existe la clase mail, por lo que lo único que no funciona es cuando se debe enviar el email de confirmación para la activación en el correo del usuario.

    No se si ya lo tienes resuelto, pero si ya lo tienes te agradecería me respondieras indicando como solucionarlo.

    POR ÚLTIMO te recomendaría al menos poner un botón de donación en tu página ya que el trabajo realizado lo merece (eso si, deberías de pulirlo para que no tuviera ningún fallo) pero salvo eso, el trabajo es muy bueno.

  8. Hola a todos,
    Gracias por el aporte, es genial.
    A mi me sale el mismo mensaje:
    Nombre de usuario o contraseña incorrectos o su cuenta no ha sido activada.
    Tengo la cuenta activada.
    Me he fijado y el problema es que no me está rellenando el campo password cuando registro el usuario. El resto de campos si los rellena.
    He probado a meter a mano la password encryptada y ha funcionado.
    Alguien podría por favor decirme por donde puedo mirar para ver porque no rellena el campo password?
    Gracias.

    1. Hola Pedro

      El detalle suele pasar porque a veces se esta usando una versión muy elevada del PHP y en localhost

      Recomendación: Trabajar con la versión 7.2 del PHP y en un servidor de producción (Servidor contratado).

      Saludos cordiales.

  9. Alguien sabe como hacer para que no puedan abrir un mismo usuario, dos o más sesiones al mismo tiempo desde distintos dispositivos…..o sea que solo un usuario pueda estar con una sesion y hasta que no la cierre no pueda abrir otra desde cualquier otro dispositivo…….. es para impedir que puedan revender accesos.

    1. Pues le comento que eso tiene que programar por medio de campos de inicio y cierre de sesion en la tabla de usuarios llenando cada campo segun lo que ingrese y salga del sistema sigo…. cualquier duda me puede escribir al mail esmupruarrobagmail.com

  10. Estoy tratando de hacer que me funcione todo, he seguido los consejos de ustedes, pero me sigue sin funcionar, resulta que cuando intento registrar un usuario me da el siguiente error «SQLSTATE[23000]: Integrity constraint violation: 1048 Column ‘password’ cannot be null» y me puse a investigar y resulta que en las últimas versiones de PHP la función mcrypt_create_iv que se utiliza en el archivo password.php queda en deshuso.
    mi pregunta ¿Cómo puedo implementar la función de password_hash en la nueva actualización de PHP?

    1. Hola Cesar

      Te está fallando por una restricción (constraint) que tienes definida en la base de datos por la cual el campo password no puede ser insertado vacío.

      Saludos Cordiales.

    2. Hola. a mi me ocurre lo mismo, pero intentaré arreglarlo, de hecho, hace días, me descargué otro ejemplo de este portal y lo pude solventar. Básicamente, se estaba utilizando una instrucción obsoleta.

      Muchas gracias, porque pocos sitios Web, presenta ejemplos completos.

  11. Buen aporte maestro, solo tengo una duda, monté su ejemplo en EasyPHP 5.3.5 el cual tiene PHP 5.3.5 y envía los correos correctamente aunque no funciona el password_hash, lo que me llevó a probarlo en una versión de EasyPHP posterior y usé la versión 14.1 en el cual si funciona el password_hash sin embargo el correo electrónico no es enviado, tiene alguna idea de que me hace falta? uso el mismo proyecto que en la versión anterior, por lo que en teoría la configuración del correo es correcta.

  12. BUENOS DIAS , AMIGO.
    la presente es una simple, ocurre q subi un login y el HOST fue dado de baja porq parece q hubo INYECCION DE CODIGO y hubo hackeo . y nos anularon la cuenta HOST+DOMINIO.
    X temor a esto, pregunto: SU SISTEMA LOGIN ES SEGURO DE PODER SUBIR A UN HOST Y Q NO SE GENERE PROBLEMAS .
    MUchas gracias por su respuesta.

  13. Muy buenas, excelente tutorial señor baulcode, le felicito. Es para comunicarle si me pude ayudar, con la parte del correo de activación, estoy usando mi servidor local con Xammp pero no sé cómo hacer que llegué el correo, es para una prueba. Si pudiera responderme muchas gracias por su ayuda.

    1. Estimado Kevin

      Este sistema de login y registros para pdoer testearlo necesita de un servidor web y a partir de su servidor obtener los correos electronicos corporativos.

      Le recomiendo que lo pruebe en un servidor de produccion y que use un email corportativo.

      Si tiene otra inquietud, no dude en consultarme.

      Saludos.

      1. Saludos señor Baulcode

        Muchísimas gracias por contestarme señor Baulcode, se lo agradezco mucho. Disculpe que le consulte otra vez. Es para preguntarle y disculpe la pregunta si es redundante, le prometo que trataré de testearlo en un servidor web (le agradecería opciones gratuitas por favor). La pregunta sería si hay una forma de testearlo en el localhost editando el código?. Muchísimas gracias por su consejo, y le agradezco mucho su respuesta, la cual espero.

        Un saludo.

  14. Que pena maestro, al colgar los archivos y tenerlos en la ubicacion raiz, el error 404 ya no sale, funciona perfectamente todos los formularios, excelente aporte .

        1. Hola Rafael,

          Disculpa por responder tarde

          Si no envía correos puede haber varios detalles por ejemplo:

          – Configurar la librería PHPMailer ingresando las credenciales de un correo electrónico(correo y contraseña)
          – Crear una cuenta de correo en el servidor de pago
          – Crear base de datos e importar las tablas
          – Configurar config.php

          Espero haberte ayudado

          1. Gracias por responder. Entiendo tus tiempos tambien. Esta bueno el ejemplo y la verdad que tengo todo el resto del sistema casi terminado pero necesitaba esto antes que nada.
            No puedo resolver esto ahora:
            SQLSTATE[23000]: Integrity constraint violation: 1048 Column ‘clave’ cannot be null.
            Gracias

  15. Todo funciona excepto que cuando envía el email de confirmación y general el link este me manda un error 404 de que no encontró el link.

    1. saludos Baulcode excelente codigo muy util, gracias por el aporte, seria bueno nos compartiera de su gran experiencia como solucionariamos el tema del link por que al dar click redirecciona a una un The requested URL was not found on this server. error 404.

      1. Hola Camilo
        Se tiene que configurar el archivo config.php

        //application address
        define(‘DIR’,’http://domain.com/’); // Define la pagina donde esta instalado el script
        define(‘SITEEMAIL’,’noreply@domain.com’); // Email del dominio existente

        Saludos cordiales

    2. Hola, Julio

      Se tiene que configurar el archivo config.php

      //application address
      define(‘DIR’,’http://domain.com/’); // Define la pagina donde esta instalado el script
      define(‘SITEEMAIL’,’noreply@domain.com’); // Email del dominio existente

      Saludos cordiales

    1. Hola Jose

      Hay que modificar el archivo config.php

      La base de datos
      El usuario de BD
      La contraseña de BD

      Además de la ruta y email

      //application address
      define(‘DIR’,’http://domain.com/’); // Define la pagina donde esta instalado el script
      define(‘SITEEMAIL’,’noreply@domain.com’); // Email del dominio existente

      Saludos cordiales

  16. hola, el sistema funciona perfecto, solo cuando voy al registro me muestra la siguiente leyenda
    —————————————————————-
    Los nombres de usuario deben tener al menos 3 caracteres alfanuméricos
    La contraseña es demasiado corta.
    Confirmar contraseña es demasiado corta.
    Por favor, introduce una dirección de correo electrónico válida
    —————————————————————
    podrian indicarme como invisivilizo eso?
    muchas gracias Daniel. elchute@gmail.com

  17. Hola.

    Gracias por el aporte. Muy buen trabajo. Pero no consigo recibir los email de confirmación.

    He cambiado los datos de la linea 15 y 16 de config.php y también he cambiado los datos de la linea 5 hasta la 12 de mail.php, pero no consigo que me se envíen los email de confirmación.

    Alguien me puede ayudar… muchas gracias

      1. Gracias Jose Luis por responderme. Te comento.
        En el archivo config.php en la linea 15 he puesto el dominio de mi web y en la 16 el email de mi dominio, y no funciona.
        Y en el archivo mail.php también he puesto mi email en la linea 6 y he desactivado todos los comentarios. No se dónde hago mal que no me funciona. Me podías ayudar donde me equivoco.

        Por otro lado agradecerte este trabajo que haces para ayudar a tanta gente, entre ellos uno soy yo.
        ¡¡¡MUCHAS GRACIAS!!!

  18. Buenos dias, lo primero agradecer el aporte 🙂
    Estoy tiendo problemas en le momento de registrar a un usuario, el mensaje de error que me dá es el siguiente:

    warning PHP:
    Warning: password_hash() expects parameter 2 to be long, string given in …/classes/password.php on line 32

    y justo encima del formulario me sale este mensaje:
    SQLSTATE[23000]: Integrity constraint violation: 1048 Column ‘password’ cannot be null

    Muchas gracias

    1. He visto que era por un problema con mi version de php. Este error me lo daba en mi virtual host que tenia una version de php diferente a la de mi servidor. En mi virtual host PASWORD_BCRYPT tenia un valor «2y» y en el mi servidor web tenia valor «1» estoy hacia que en la comprobación de si es integer en la linea 32 del archivo password.php me diera error.

      Gracias y disculpe las molesetias

  19. Estimado Baulcode, desestimen los mensajes anteriores, modifiqué el config.php y el mail.php y salio andando todo de una, buenísimo!. Muchas gracias por este material!. Saludos!.

  20. Hola, dejé hace unas horas un mensaje pero no lo vi más estaba en espera de ser aceptado, dada mi necesidad de respuesta vuelvo a dejar mi pregunta, si esta duplicada sabrán Uds. disculpar y eliminar la que crean oportuna.
    La duda que tengo es similar a la de mis colegas que tu has respondido, te pido disculpas y paciencia pero no logro hacer llegar el mail a la cuenta que se quiere registrar aunque si hace joined, como no tengo aun un sitio web estoy con el localhost de easyphp, mi sintaxis en config.php es esta y no funciona podrás tu ayudarme a dilucidar el problema? te lo agradecería.

    //application address
    define(‘DIR’,’http://localhost/LoginPDO/’);
    define(‘SITEEMAIL’,’comprodesdecasa20@gmail.com’);

    Ademas de los errores que este cometiendo aquí, hay que modificar algún otro archivo, digo porque veo en mail.php esto comentado y estoy en dudas:

    class Mail extends PhpMailer
    {
    // Set default variables for all new objects
    public $From = ‘noreply@domain.com’;
    public $FromName = SITETITLE;
    //public $Host = ‘smtp.gmail.com’;
    //public $Mailer = ‘smtp’;
    //public $SMTPAuth = true;
    //public $Username = ‘email’;
    //public $Password = ‘password’;
    //public $SMTPSecure = ‘tls’;
    public $WordWrap = 75;

    Agradezco mucho tu ayuda!!

  21. Estimado Igmar, ayer me tope con este desarrollo y me parece fabuloso y justo lo que venia necesitando, quizás mas!. Para no desentonar con los amigos que me preceden en este chat te vengo con lo mismo y te pido mil disculpas pero yo modifico en config.php esas lineas así textual como las pego aquí y si bien hace join nunca recibo mail de confirmación, espero puedas ayudarme porque lo que es esto me fascina. Pego aquí mi código tal cual.
    //application address
    define(‘DIR’,’http://127.0.0.1/login-y-registro-pdo-php-y-mysql-ejemplo-completo/’);
    define(‘SITEEMAIL’,’comprodesdecasa20@gmail.com’);

    Es que cometo algún error sintáctico y no lo veo, las comillas son simples tal cual aquí.
    Otra consulta, esto está en mail.php todo comentado, debo descomentarlo?

    // Set default variables for all new objects
    // public $From = ‘noreply@domain.com’;
    // public $FromName = SITETITLE;
    //public $Host = ‘smtp.gmail.com’;
    //public $Mailer = ‘smtp’;
    //public $SMTPAuth = true;
    //public $Username = ‘email’;
    //public $Password = ‘password’;
    //public $SMTPSecure = ‘tls’;
    // public $WordWrap = 75;
    Agradezco tu aporte y ayuda, un saludo!.

  22. hola. me podrías ayudar coloco la información del dominio y el correo y el mail de confirmación no llega.

    //application address
    define(‘DIR’,’http://jasolutionsweb.com’);
    define(‘SITEEMAIL’,’noreply@jasolutionsweb.com’);

  23. hola, como hago para que en la pagina de memberpage.php mostrar contenido especifico para cada usuario registrado.

    es decir que tenga 3 usuarios verdad
    usuario1, usuario2 y usuario 3.
    cómo hago para mostrar en memberpage.php por ejemplo 3 o 4 botones con funciones especificas para ese usuario sin que los demas usuarios la vean, pero los demas usuarios tambien tengan 2 o 3 botones especificos para hacer una tarea, pero que los demas usuarios no puedan ver esos botones, solo el usuario al que se le asigna o si se puede crear una pagina persosalizada como funciones especificas a cada usuario pero que la misma sea mostrada en memberpage.php o que sean enviado cada uno a su pagina privada que solo ellos puedan ver.

    ejemplo accedio el usuario1, pero que al accede el pueda ver su contenido paginauser1.php por ejemplo.
    accede el usuario2 y a este se le muestra su pagina con su contenido paginauser2.php y
    si accede el usuario3 este vea su contenido paginauser3.php

    pero que ninguno pueda ver la pagina que no le corresponde salvo el usuario principal como admin o algo asi que pueda acceder a todas.

    en scrip se puede hacer, pero no se recomienda porque s se da ver codigo fuente se ven los accesos.
    yo creo que esta funcion se llama con php usando el id del usuario para imprimir el contenido de la pagina en memberpage.php pero no se como hacerlo que el php llame a la pagina especifica dependiendo del usuario conectado

    no se si me explico.

    1. porque no has configurado la info del dominio donde tienes el sistema de registro, esta info se coloca en: /include/config.php

      en esta seccion:
      //application address
      define(‘DIR’,’http://dominio.com/’);
      define(‘SITEEMAIL’,’correo@dominio.com’);

  24. Hola buenas noches está muy interesante este formulario de ingreso. Me gustaría saber porque después de registrarme y de acceder al login aparece como error «no coinciden usuario o password» o que la cuenta no esta activada. Me podrían colaborar con eso por favor. Muchas gracias.

  25. jhon jairo rodallega

    buenas

    porque me sale este mensaje y no me deja iniciar sesión
    Nombre de usuario o contraseña incorrectos o su cuenta no ha sido activada.

    1. porque tienes que activarla, sino agregas el dominio donde tienes el login y un correo, no va a enviar el correo de conformacion para que active la cuenta el usuario

    1. Hola Manuel,
      Primero tienes que analizar tu sistema y el nuevo sistema para poder reemplazar sin problemas, por ejemplo las tablas y clases.

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

Scroll al inicio