IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

formulaire de connexion


Sujet :

PHP & Base de données

  1. #1
    Invité
    Invité(e)
    Par défaut formulaire de connexion
    Bonjour,

    Je débute en php. En parcourant différents forum, j'ai fais un formulaire d'inscription qui fonctionne correctement et que voici.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    <?php
     
     
    $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    $bdd = new PDO('mysql:host=localhost;dbname=fonctions', 'root', '',   $pdo_options);
     
    $erreurs = [];
    if(empty($_POST['pseudo'])) {
        $erreurs[] = 'Veuillez entrer un pseudo';
    } else {
        $stmt = $bdd->prepare('SELECT COUNT(*) FROM abonnes WHERE pseudo = :pseudo');
        $stmt->execute(['pseudo' => $_POST['pseudo']]);
        if ($stmt->fetchColumn()) {
            $erreurs[] = 'Ce pseudo est déjà utilisé';
        }
    }
    if(empty($_POST['mdp'])) {
        $erreurs[] = 'Veuillez entrer un mot de passe';
    } elseif($_POST['mdp'] != $_POST['mdp_confirm']) {
        $erreurs[] = 'mots de passes différents ';
    }
    if(empty($_POST['mail'])) {
        $erreurs[] = 'Veuillez entrer un mail';
    } elseif($_POST['mail'] != $_POST['mail_confirm'])
        $erreurs[] = 'les deux adresses emails sont différentes ';
     
    if ($erreurs) {
        echo '<ul><li>', implode('</li><li>', $erreurs), '</li></ul>';
    } else {
     
    	$req = $bdd->prepare('INSERT INTO abonnes(pseudo, mdp, mail) VALUES(:pseudo, :mdp, :mail)');
        $req->execute([
            'pseudo' => $_POST['pseudo'],
            'mdp' => $_POST['mdp'],
            'mail' => $_POST['mail'],
        ]);
     
        header('Location: inscription.php');
    }
     
    ?>
    cependant, mon formulaire de connexion ne fonctionne pas. Il ne doit pas s'agir de grand chose, mais je ne comprends pas l'erreur... .

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    <?php
    $fail = FALSE;
    if ('POST' == $_SERVER['REQUEST_METHOD']) {
        require('shared.php');
     
        $stmt = $bdd->prepare('SELECT * FROM abonnes WHERE pseudo = :pseudo');
        $stmt->execute(['pseudo' => $_POST['pseudo']]);
        if ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
            if (password_verify($_POST['mdp'], $row['mot_de_passe'])) {
                session_start();
                $_SESSION['id'] = $row['id'];
                if (password_needs_rehash($row['mot_de_passe'], $password_options['algo'], $password_options['options'])) {
                    $stmt = $bdd->prepare('UPDATE abonnes SET mot_de_passe = :new_hash WHERE id = :id');
                    $stmt->execute(['id' => $row['id'], 'new_hash' => password_hash($_POST['mdp'], $password_options['algo'], $password_options['options'])]);
                }
                header('Location: index.php');
                exit;
            } else {
                $fail = TRUE;
            }
        } else {
            $fail = TRUE;
        }
    }
    ?>
    pourriez-vous m'aider?


    merci d'avance

  2. #2
    Membre averti
    Avatar de Dumbeldor
    Homme Profil pro
    Développeur Concepteur Banque postale / Ecole d'ingénieur Alternance
    Inscrit en
    Novembre 2013
    Messages
    88
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Landes (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Concepteur Banque postale / Ecole d'ingénieur Alternance

    Informations forums :
    Inscription : Novembre 2013
    Messages : 88
    Points : 301
    Points
    301
    Par défaut
    Salut Julien,

    Pour ton premier if je suis pas trop d'accord.
    Je préfère faire un :

    if(isset($_POST['pseudo'], $_POST['mdp']))

    C'est plus clair je trouve. Après tu peux me dire ce qui se passe quand tu essayes de te connecter ?
    N'oubliez pas de mettre un petit pouce vert si mon message vous a aidé !

  3. #3
    Invité
    Invité(e)
    Par défaut
    Merci de bien vouloir m'aider.

    En fait, avec le code actuel, j'obtiens toujours "Aucun utilisateur ne correspond à ce couple pseudo/mot de passe." même lorsque le couple pseudo est mot de passe est bien dans la base de données. Selon moi, le problème doit venir de la ligne 9, mais sans plus de certitude... .

  4. #4
    Invité
    Invité(e)
    Par défaut
    quelqu'un pourrait m'aider?

  5. #5
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Le mot de passe que tu inseres dans la base de données n'est pas haché.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  6. #6
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par sabotage Voir le message
    Le mot de passe que tu inseres dans la base de données n'est pas haché.
    donc si je supprime la partie

    if (password_needs_rehash($row['mot_de_passe'], $password_options['algo'], $password_options['options'])) {
    $stmt = $bdd->prepare('UPDATE abonnes SET mot_de_passe = :new_hash WHERE id = :id');
    $stmt->execute(['id' => $row['id'], 'new_hash' => password_hash($_POST['mdp'], $password_options['algo'], $password_options['options'])]);
    }

    ça devrait être juste?

  7. #7
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Pour le savoir, il suffit d'essayer.

    Mais bon la bonne démarche serait plutôt de hacher les mots de passe à l'insertion.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  8. #8
    Invité
    Invité(e)
    Par défaut
    D'accord, merci.

    dans un premier temps, j'ai retiré la partie hachée, et j'ai constaté que j'étais connecté lorsque dès que j'entre la partie 'pseudo' correcte, le formulaire de connexion marche. Donc, la partie mot de passe ne fonctionne pas.

    Je ne trouve pas l'erreur.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    <?php
    $fail = FALSE;
     
    if ('POST' == $_SERVER['REQUEST_METHOD']) {
        require('shared.php');
     
        $stmt = $bdd->prepare('SELECT * FROM abonnes WHERE pseudo = :pseudo');
        $stmt->execute(['pseudo' => $_POST['pseudo']]);
        if ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
            if (password_verify($_POST['mdp'], $row['mdp'])) {
                session_start();
                $_SESSION['id'] = $row['id'];
                }
                header('Location: index.php');
                exit;
            } else {
                $fail = TRUE;
            }
        } else {
            $fail = TRUE;
        }
     
    ?>

  9. #9
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Comme je t'ai dit, il faut hacher le mot de passe lors de l'insertion. Ton code est prévu comme ça.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  10. #10
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par sabotage Voir le message
    Comme je t'ai dit, il faut hacher le mot de passe lors de l'insertion. Ton code est prévu comme ça.
    dans le formulaire html?

  11. #11
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    nonn lors de l'insertion
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  12. #12
    Invité
    Invité(e)
    Par défaut
    comment hacher?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (password_verify($pass, $hash)) {
        if (password_needs_rehash($hash, $algorithm, $options)) {
            $hash = password_hash($pass, $algorithm, $options);
        }
    }
    ?
    Dernière modification par sabotage ; 19/07/2015 à 15h22.

  13. #13
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Comme tu débutes, je te conseille de lire des articles et d’expérimenter plutôt que de copier/coller du code.

    http://grunk.developpez.com/tutoriel...sse-securises/
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

Discussions similaires

  1. Formulaire de connexion qui ne connecte pas
    Par Lexion71 dans le forum Langage
    Réponses: 3
    Dernier message: 28/12/2007, 18h41
  2. Formulaire de connexion
    Par Interface dans le forum Langage
    Réponses: 6
    Dernier message: 21/09/2007, 14h06
  3. formulaire de connexion ne fonctionne pas
    Par masterix59 dans le forum Langage
    Réponses: 2
    Dernier message: 20/09/2007, 00h31
  4. formulaire de connexion utilisateurs
    Par lucienkany dans le forum Access
    Réponses: 1
    Dernier message: 02/07/2007, 22h45
  5. PB Utilisation formulaire de connexion
    Par stan314 dans le forum Access
    Réponses: 2
    Dernier message: 25/05/2006, 12h59

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo