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

Administration MySQL Discussion :

mysql_fetch_objet => erreur


Sujet :

Administration MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    102
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Avril 2004
    Messages : 102
    Par défaut mysql_fetch_objet => erreur
    Bonjour,

    Je suis en train de developper (enfin, "essayer de développer") une petite application pour le boulot.
    Je débute en PHP et je suis déjà bloqué au contrôle du Login.

    Lorsque j'exécute le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $request=mysql_query("SELECT login, pass FROM users WHERE login LIKE '$login' AND pass LIKE '$pass';");
      $result=mysql_fetch_object($request);
      if ($pass==$result->pass)
      {
        echo ("Connexion autorisée");
        //header("location: ");
      }
    Je reçois l'erreur :
    Notice: Trying to get property of non-object in c:\program files\easyphp1-8\www\planningchargement\connexion.php on line 19
    Cette ligne 19 correspond à mon "if".

    Je ne comprends pas où se situe le problème.

    Pour info, je travaille avec EasyPHP 1.8 sur lequel j'ai appliqué PHP5.

    Merci d'avance pour votre aide

  2. #2
    Expert confirmé Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Par défaut
    Que vaut $pass ?

    EDIT: en fait c'est juste par curiosité, ca ne va pas résoudre forcément ton pb

  3. #3
    Membre émérite Avatar de FCYPBA
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2004
    Messages : 745
    Par défaut
    Il faudrait vérifier que ta requète renvoie un résultat.

    Tu peux ajouter un test supplémentaire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $request=mysql_query("SELECT login, pass FROM users WHERE login LIKE '$login' AND pass LIKE '$pass';");
    if ( mysql_num_rows($request)>0){
    while($result=mysql_fetch_object($request)){
    if ($pass==$result->pass){
    echo ("Connexion autorisée");
    //header("location: ");
    }
    }
    }
    Avec ceci tu vérifies que la requet a renvoyé des lignes.
    Ensuite la boucle while te permet de parcourir toutes les lignes renvoyées ( on ne sait jamais

    Sinon, pour tester qu'une personne a donné les bons identifiants évite les like. Remplace les par des =.

  4. #4
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Juin 2005
    Messages
    12
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2005
    Messages : 12
    Par défaut
    ...et attention aux injections SQL avec ce code

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    102
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Avril 2004
    Messages : 102
    Par défaut
    Le "While" ne change rien, j'ai toujours le même problème.
    J'ai essayé de remplacer les "LIKE" par "=" et c'est toujours pareil.

    Une autre idée ?

    ...et attention aux injections SQL avec ce code
    Qu'est-ce que tu entends par là ?

  6. #6
    Membre émérite
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juin 2003
    Messages
    910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 910
    Par défaut injections SQL
    C'est la fameuse faille hyper connue que le peut injecter avec ' OR 1='1'

    est-ce que tu as fait un mysql_select_db pour pouvoir utiliser mysql_query au lieu de mysql-db_query?

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Erreur fréquente avec ASP et IIS
    Par Community Management dans le forum ASP
    Réponses: 2
    Dernier message: 11/02/2004, 22h20
  2. Check Url pour savoir si erreur 404 ou si le site existe
    Par Clément[Delphi] dans le forum Composants VCL
    Réponses: 2
    Dernier message: 07/08/2002, 13h49
  3. Réponses: 2
    Dernier message: 27/05/2002, 19h46
  4. erreur IDL:omg.org/CORBA/MARSHAL:1.0
    Par Pinggui dans le forum CORBA
    Réponses: 3
    Dernier message: 13/05/2002, 15h05
  5. [Kylix] Erreur objet
    Par Anonymous dans le forum EDI
    Réponses: 1
    Dernier message: 22/03/2002, 09h41

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