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 :

Commande SELECT résultat toujours faux


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Inscrit en
    Novembre 2006
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 57
    Par défaut Commande SELECT résultat toujours faux
    Bonjours ;
    Ce bout de code est le contenu de la page d'activation d'un compte
    dés que j'active le compte a partir de mon email le resultat est toujours faux c-a-d au niveau de mysqli_num_rows($result) est toujours 0
    je n'arrive pas a localiser mon erreur
    si quelqu'un a une idée je serais ravi
    @+

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <?php
    if(isset($_GET['id'])&&isset($_GET['code']))
    {
      $id = $_GET['id'];
      $code = $_GET['code'];    
      $connbd = mysqli_connect('localhost','user','mdp','bdd') or die('error');
      $result=mysqli_query($connbd,"SELECT * FROM users WHERE id='$id' AND token='$code'");
        if(mysqli_num_rows($result)==1)
        {
           $act = mysqli_query($connbd,"UPDATE users SET active='1' WHERE id='$id'");
           die("Votre Compte a été activé vous pouvez vous <a href='login.php'>Connecter</a>"); 
        }else echo'Identificateur ou Token invalide !..';    
    }else echo'Information introuvable';    
    ?>

  2. #2
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 322
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 322
    Billets dans le blog
    17
    Par défaut
    Je ne vois pas d'erreur flagrante. Affiche tes variables pour vérifier leur validité :

    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
    <?php
     
    echo 'DEBUG $_GET = ';
    print_r($_GET);
     
    if(isset($_GET['id'])&&isset($_GET['code']))
    {
        $id = $_GET['id'];
        $code = $_GET['code'];
        $connbd = mysqli_connect('localhost','user','mdp','bdd') or die('error');
        echo 'DEBUG $connbd = ';
        var_dump($connbd);
        $sql = "SELECT * FROM users WHERE id='$id' AND token='$code'";
        echo 'DEBUG $sql = ', $sql;
        $result=mysqli_query($connbd, $sql);
        echo 'DEBUG $result = ';
        var_dump($result);
        if(mysqli_num_rows($result)==1)
        {
            // ...
            $act = mysqli_query($connbd,"UPDATE users SET active='1' WHERE id='$id'");
            die("Votre Compte a été activé vous pouvez vous <a href='login.php'>Connecter</a>");
        } else echo'Identificateur ou Token invalide !..';
    } else echo'Information introuvable';
    Et il faudra utiliser mysqli_error() pour avoir le détail si une fonction mysqli retour false/null.

  3. #3
    Membre actif
    Inscrit en
    Novembre 2006
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 57
    Par défaut Problème avec la commande SELECT
    Bonjours ;
    Tout d'abord merci pour ta réponse rapide j'ai exécuter le script comme convenu voilà ce que le serveur me renvoi l'id=12 et le code=62371 sont correct j'ai vérifier au niveau de la BDD

    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
    DEBUG $_GET = Array ( [id] => '12' [code] => '62371' ) 
    DEBUG $connbd = object(mysqli)#1 (19) {
    	["affected_rows"]=> int(0)
    	["client_info"]=> string(79) "mysqlnd 5.0.12-dev - 20150407 - $Id: 7cc7cc96e675f6d72e5cf0f267f48e167c2abb23 $"
    	["client_version"]=> int(50012)
    	["connect_errno"]=> int(0)
    	["connect_error"]=> NULL
    	["errno"]=> int(0)
    	["error"]=> string(0) ""
    	["error_list"]=> array(0) { }
    	["field_count"]=> int(0)
    	["host_info"]=> string(25) "Localhost via UNIX socket"
    	["info"]=> NULL
    	["insert_id"]=> int(0)
    	["server_info"]=> string(21) "5.5.5-10.3.29-MariaDB"
    	["server_version"]=> int(100329) 
    	["stat"]=> string(152) "Uptime: 87230 Threads: 187 Questions: 39984124 Slow queries: 1518 Opens: 558349 Flush tables: 1 Open tables: 4800 Queries per second avg: 458.375" 
    	["sqlstate"]=> string(5) "00000" 
    	["protocol_version"]=> int(10) 
    	["thread_id"]=> int(1730092) 
    	["warning_count"]=> int(0)
    }
    DEBUG $sql = SELECT * FROM users WHERE id=''12'' AND token=''62371''
    DEBUG $result = bool(false)
    Identificateur ou Token invalide !..

  4. #4
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 322
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 322
    Billets dans le blog
    17
    Par défaut
    Le debug de $sql que tu as collé contient ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DEBUG $sql = SELECT * FROM users WHERE id=''12'' AND token=''62371''
    Il y a des ' surnuméraires qui posent problème.

  5. #5
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    je crois qu'une solution serait d'écrire le requête SQL "SELECT * FROM users WHERE id='{$id}' AND token='{$code}'". C'est justement Séb. qui m'a appris cette syntaxe.

    EDIT : autre point ; pour afficher la valeur des variables en mode debug, comme souvent, quand on a plus besoin de cet affichage, on se rappelle plus (du moins moi) dans quel fichier il est, j'ai créé cette fonction où j'affiche le nom du fichier, le numéro de ligne et le nom de la variable.

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function debug($location, $var)
    {
        // exemple : debug("index.php 70 get ",$_GET);
        echo "<br/>".(is_string($location))?$location:''."<br/><pre>";
        var_dump($var);
        echo "</pre><br/>";
    }

  6. #6
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 322
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 322
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    je crois qu'une solution serait d'écrire le requête SQL
    Salut laurentSc Je ne pense pas que la syntaxe "{$foo}" corrigerait le problème (c'est juste une manière de bien délimiter la variable dans la chaîne).

    Pour une solution immédiate il faudrait au choix
    1. Supprimer les délimiteurs ' dans la requête SQL (−−)
    2. Supprimer les ' à la source (les ' sont déjà présents dans le $_GET => Voir le formulaire) (++)

Discussions similaires

  1. [AC-2016] ComboBox.Selected toujours faux
    Par Guillaume1077 dans le forum VBA Access
    Réponses: 8
    Dernier message: 26/04/2017, 17h29
  2. Select:Résultat commence à la 2ème ligne
    Par jeanpaul702 dans le forum Oracle
    Réponses: 8
    Dernier message: 06/06/2006, 16h01
  3. Requete selection : résultat non modifiable
    Par patal dans le forum Access
    Réponses: 3
    Dernier message: 09/05/2006, 17h31
  4. Equivalent de la commande Select de linux pour Windows
    Par bibi_64 dans le forum Windows
    Réponses: 2
    Dernier message: 18/10/2005, 09h39
  5. [Delphi 2005][INTERBASE] isEmpty toujours faux
    Par Vulcanos dans le forum Bases de données
    Réponses: 2
    Dernier message: 26/03/2005, 20h43

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