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 :

mysql_fetch_array() en PDO


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 12
    Par défaut mysql_fetch_array() en PDO
    Bonsoir,

    Pour mon site web j'aimerais réaliser une connexion grâce à des identifiants, le reste de mes requête étant en PDO je souhaiterais mettre le code que j'ai trouve en PDO également

    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
     
    <?php
    $sql = 'SELECT count(*) FROM membre WHERE login="'.mysql_escape_string($_POST['login']).'" AND pass_md5="'.mysql_escape_string(md5($_POST['pass'])).'"';
    $req = mysql_query($sql)
    $data = mysql_fetch_array($req);
     
    	// si on obtient une réponse, alors l'utilisateur est un membre
    if ($data[0] == 1) {
    	session_start();
    	$_SESSION['login'] = $_POST['login'];
    	header('Location: membre.php');
    	exit();
    }
    // si on ne trouve aucune réponse, le visiteur s'est trompé soit dans son login, soit dans son mot de passe
    elseif ($data[0] == 0) {
    	$erreur = 'Compte non reconnu.';
    }
    // sinon, alors la, il y a un gros problème :)
    else {
    	$erreur = 'Probème dans la base de données : plusieurs membres ont les mêmes identifiants de connexion.';
    }
    ?>
    J'ai un problème pour retranscrire la ligne 4 , j'ai essayer avec un fetch mais je reçois le message d'erreur suivant : "atal error: Call to a member function fetch() on a non-object"


    voici mon 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
     
    <?php 
     
    $sql = "SELECT COUNT(*) FROM user WHERE login=$log AND mdp=$mdpass;";
    $donnees= $BDD->query($sql) 
    $data = $donnnees->fetchAll();
     
    	// si on obtient une réponse, alors l'utilisateur est un membre
    if ($data[0] == 1) { 
    	session_start(); 
    	$_SESSION['login'] = $_POST['login']; 
    	header('Location: membre.php'); 
    	exit(); 
    	} 
     
    	// si on ne trouve aucune réponse, le visiteur s'est trompé soit dans son login, soit dans son mot de passe
    elseif ($data[0] == 0) { 
    	$erreur = 'Compte non reconnu.'; 
    	} 
    	// sinon, alors la, il y a un gros problème :)
    else { 
    	$erreur = 'Probème dans la base de données : plusieurs membres ont les mêmes identifiants de connexion.'; 
    	 }
    ?>

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    t'as oublier les guillemets dans ta requête autour de tes valeurs,
    et pour faire 1 fetch c'est fetch pas fetchAll

    active les erreurs pour PDO sinon tu vas pas t'en sortir
    http://php.net/manual/fr/pdo.error-handling.php

Discussions similaires

  1. [PDO] mysql_fetch_array en PDO
    Par hellosct1 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 27/09/2007, 11h41
  2. [SGBD] Trier un tableau crée avec mysql_fetch_array
    Par kaygee dans le forum SQL Procédural
    Réponses: 14
    Dernier message: 07/01/2006, 21h02
  3. erreur mysql_fetch_array()
    Par speedylol dans le forum Requêtes
    Réponses: 3
    Dernier message: 05/01/2006, 12h00
  4. [SGBD] Warning: mysql_fetch_array()
    Par talme dans le forum Installation
    Réponses: 2
    Dernier message: 03/11/2005, 04h39
  5. [SGBD] mysql_fetch_array provoque une erreur
    Par nicerico dans le forum Requêtes
    Réponses: 6
    Dernier message: 06/10/2005, 14h20

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