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

Langage PHP Discussion :

mot de passe oublié - Query was empty


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 97
    Par défaut mot de passe oublié - Query was empty
    Bonjour,

    L'utilisateur clique sur un lien "mot de passe oublié".
    Problème à l'ouverture de cette page : "Query was empty" avant même qu'il puisse saisir son mail et valider le formulaire.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <form action="<?php echo $loginFormAction; ?>" method="POST" name="connect_client" >
    <p class="titre_champ_form_contact">E-mail
    <label><input name="mail" type="text" id="mail" size="30" maxlength="60" class="champ_form_contact"></label>
    <label><input type="submit" name="connect" id="connect" value="OK" class="titre_champ_form_contact"></label></p></form>
    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
     
    $loginFormAction = $_SERVER['PHP_SELF'];
    $mail = $_POST['mail'];
     
    //pas besoin de faire un count
    $sql = "SELECT mail FROM client WHERE mail = '".$mail."' ";
    $req = mysql_query($sql__query, $xxx) or die(mysql_error());
     
    if(mysql_num_rows($req) != 1)//si le nombre de lignes retourne par la requete != 1
    exit("mail inconnu.");
    else
    {
    $row1 = mysql_fetch_assoc($req);
    $retour = mysql_query("SELECT nom, prenom, mot_passe FROM client WHERE mail = '".$mail."' ");
    $row2 = mysql_fetch_assoc($retour);
     
    $destinataire = $_POST['mail'];
    // Pour les champs $expediteur / $copie / $destinataire, séparer par une virgule s'il y a plusieurs adresses
    $expediteur = 'insciption.client@xxx.com';
    $objet = 'Rappel de vos identifiants'; // Objet du message
    $headers  = 'MIME-Version: 1.0' . "\n"; // Version MIME
    $headers .= 'Content-type: text/html; charset=UTF-8'."\n"; // l'en-tete Content-type pour le format HTML
    $headers .= 'Reply-To: '.$expediteur."\n"; // Mail de reponse
    $headers .= 'From: "xxx.com"<'.$expediteur.'>'."\n"; // Expediteur
    $headers .= 'Delivered-to: '.$destinataire."\n"; // Destinataire
    $message = ...
     
    if(!mail($row1['mail'], $objet, $row2['mot_passe'], $headers))
    echo 'probleme lors de l\'envoi du mail';
    else
    echo 'mail envoye';
    }
    Je crois que le script de l'action du formulaire est mauvaise ou incomplète mais je ne sais pas ce que je dois mettre...

  2. #2
    Rédacteur
    Avatar de RideKick
    Homme Profil pro
    Directeur technique
    Inscrit en
    Septembre 2006
    Messages
    5 914
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Septembre 2006
    Messages : 5 914
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $mail = $_POST['mail'];
    lors du premier accès mail est vide donc ta requete ne renvoi aucun enregistrement.

    Tu devrai encadrer ton code d'un if qui verifie si le formulaire a ete envoyé
    Pas de questions techniques en MP please

    Mon site perso

    Mon profil Viadeo

  3. #3
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Et aussi si tu exécutais la bonne requête...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $sql = "SELECT mail FROM client WHERE mail = '".$mail."' ";
    $req = mysql_query($sql__query, $xxx) or die(mysql_error());
    EDIT : pour être honnête j'ai eu la même erreur pas plus tard que ce matin, alors ça aide
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  4. #4
    Rédacteur
    Avatar de RideKick
    Homme Profil pro
    Directeur technique
    Inscrit en
    Septembre 2006
    Messages
    5 914
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Septembre 2006
    Messages : 5 914
    Par défaut
    Bien vu cel, je ne m'expliquais pas le fameux message, la par contre tout devient clair
    Pas de questions techniques en MP please

    Mon site perso

    Mon profil Viadeo

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 97
    Par défaut
    MERCI j'ai modifié : mysql_query($sql)

    Par contre,

    Citation Envoyé par RideKick Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $mail = $_POST['mail'];
    lors du premier accès mail est vide donc ta requete ne renvoi aucun enregistrement.

    Tu devrai encadrer ton code d'un if qui verifie si le formulaire a ete envoyé
    Pourrais-tu me donner un exemple stp ?
    J'ai essayé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if(!empty($_POST['mail']))
    $mail = $_POST['mail'];
    else
    exit("mail vide.");
    Mais à chaque fois ça affiche "mail vide" avant de pouvoir remplir le formulaire.

  6. #6
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (isset($_POST)) // signifie "si un formulaire a été soumis"
    if (isset($_POST['mail'])) // signifie "si $_POST['mail']" a été soumis
     
    // Et voici comment on fera généralement (enfin ça dépend aussi du nombres de var à tester
    if (isset($_POST['mail']) && !empty($_POST['mail']))

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 97
    Par défaut
    Merci pour ta réponse.
    Voici mon nouveau code
    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
     
    if (isset($_POST['mail']) && !empty($_POST['mail'])){
    $mail = $_POST['mail'];
    } 
     
    $sql = "SELECT mail FROM client WHERE mail = '".$mail."' ";
    mysql_select_db($database_xxx, $xxx);
    $req = mysql_query($sql, $xxx) or die(mysql_error());
     
    if(mysql_num_rows($req) != 1)
    exit("mail inconnu.");
    else
    {
    $row1 = mysql_fetch_assoc($req);
    $retour = mysql_query("SELECT nom, prenom, mot_passe FROM client WHERE mail = '".$mail."' ");
    $row2 = mysql_fetch_assoc($retour);
     
    $destinataire = $_POST['mail'];
    $expediteur = ...
    ...
    $message = ...
    if(!mail($row1['mail'], $objet, $row2['mot_passe'], $headers))
    echo 'probleme lors de l\'envoi du mail';
    else
    echo 'mail envoye';
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <form method="POST">
    <p class="titre_champ_form_contact">E-mail
    <label><input name="mail" type="text" id="mail" size="30" maxlength="60" class="champ_form_contact"></label>
     <label> <input type="submit" name="connect" id="connect" value="OK" class="titre_champ_form_contact"></label>  </p></form>
    Je n'accède toujours pas au formulaire, je tombe directement sur "mail inconnu."

    Est-ce que ça peut avoir un lien avec le fait qu'il n'y ait aucune action au form ?

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 19
    Par défaut
    hello
    il faut ajouter le nom du fichier qui doit recevoir les données du formulaire dans action
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <form method="post" action="nom_du_fichier.php">

Discussions similaires

  1. mot de passe oublié!
    Par starsat4200 dans le forum Excel
    Réponses: 4
    Dernier message: 08/06/2007, 20h04
  2. [ADODB] erreur Query was empty
    Par Invité dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 26/01/2007, 20h18
  3. Réponses: 5
    Dernier message: 18/04/2006, 09h40
  4. [authentification]mot de passe oublié
    Par dash dans le forum Access
    Réponses: 5
    Dernier message: 08/12/2005, 11h35
  5. mot de passe oublié
    Par sami1881 dans le forum Sécurité
    Réponses: 5
    Dernier message: 25/11/2005, 00h04

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