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 :

bindé une valeur avec une requête IN()


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut bindé une valeur avec une requête IN()
    Bonsoir voici une requête préparer:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ->prepare("SELECT * FROM produit WHERE idProduit IN ($this->id_produit_modifier)");
    peut t'on faire une injection sql sur cette requête ?
    comment peut t'on binder id_produit_modifier avec pdo ?

    merci de vos réponses

  2. #2
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 672
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 672
    Par défaut
    en faisant une boucle qui parcourt les valeurs, vous pouvez construire une requête qui donnera "... WHERE idProduit IN (?, ?, ?, ?)"
    et ensuite vous passez les valeurs à "execute"

  3. #3
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 418
    Par défaut
    Oui ta requête était sensible aux injections car il ne suffit pas d'utiliser la fonction prepare, encore faut-il utiliser des marqueurs comme l'a dit mathieu. La doc est ici

  4. #4
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut
    merci de la réponse ,
    tu veux dire comme l'exemple de la document php ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     
    <?php
    /* Exécute une commande préparée en utilisant un tableau de valeurs pour les clauses IN */
    $params = array(1, 21, 63, 171);
    /* Crée une chaîne pour les marqueurs */
    $place_holders = implode(',', array_fill(0, count($params), '?'));
    $sth = $dbh->prepare("SELECT id, name FROM contacts WHERE id IN ($place_holders)");
    $sth->execute($params);
    ?>
    avec cette requête il n'y a pas de risque d'injection SQL? même si l'on ne vérifie pas le bon type number qui est dans l'array ?

    sinon j'ai essayé ceci et je n'ai pas pas de donnée affiché au niveau de $r->nom et $r->prix
    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
     
            $sth =Bdd::getIntance()->prepare("SELECT * FROM produit WHERE idProduit:id"); // IN ($this->id_produit_modifier)");
            $tb_IN = explode(',',$this->id_produit_modifier );
            var_dump($tb_IN);
            foreach($tb_IN as $id)
            {
                echo $id;
                $sth->bindParam(':id', $id);
                $sth->execute();
            }
     
            echo '<a href="index.php">revenir</a>';
            echo "<table>";
            echo "<tr><th>numéro</th><th>nom</th><th>prix</th><th>afficher/cacher</th></tr>";
     
            while($r = $sth->fetch(PDO::FETCH_OBJ)) {
            echo "</tr>
                <td>$r->nom</td>
                <td>$r->prix</td>
                <td>show</td>
                </tr> ";
            }
            echo "</table>";

  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
    Par défaut
    Déjà il manque le = dans la requête, c'est une bonne raison pour ne rien recevoir.
    Mais également si tu fais des SELECT en boucle, tu ne recolteras pas la totalité des resultats dans ton fetch mais bien uniquement ceux de la dernière requête.

    Suivre l'exemple de la doc plutôt que d'inventer est bien sûr une saine chose à faire.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  6. #6
    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
    Citation Envoyé par keokaz Voir le message
    avec cette requête il n'y a pas de risque d'injection SQL? même si l'on ne vérifie pas le bon type number qui est dans l'array ?
    Je ne comprends ce que tu veux dire par "vérifier le bon type number dans l'array".

    En mixant le code de l'exemple et le tien, on peut écrire ça :

    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
    // tableau des valeurs à passer dans le IN
    $tb_IN = explode(',',$this->id_produit_modifier );
    var_dump($tb_IN);
    // Crée une chaîne pour les marqueurs 
    $place_holders = implode(',', array_fill(0, count($tb_IN), '?'));
     
    $sth =Bdd::getIntance()->prepare("SELECT * FROM produit WHERE idProduit IN ($place_holders)"); // IN ($this->id_produit_modifier)");
    $sth->execute($tb_IN);
     
    echo '<a href="index.php">revenir</a>';
    echo "<table>";
    echo "<tr><th>numéro</th><th>nom</th><th>prix</th><th>afficher/cacher</th></tr>";
     
    while($r = $sth->fetch(PDO::FETCH_OBJ)) {
    echo "</tr>
        <td>$r->nom</td>
        <td>$r->prix</td>
        <td>show</td>
        </tr> ";
    }
    echo "</table>";
    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]

  7. #7
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut
    merci de ta réponse

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Je ne comprends ce que tu veux dire par "vérifier le bon type number dans l'array".
    en fait je voulais dire par exemple si dans IN on met des lettre à la place des chiffres, il refusera d'exécuter la requête, puisque qu'on s'attendra
    d'avoir uniquement d'avoir un INT plutôt qu'une chaîne de caractère, mais c'est peut être exagérer comme validation puisque même si la requête passe,
    dans on champs 'idProduit' je n'ai mis que des nombres, au pire il ne trouvera rien.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    IN(1,2,'2','5','a');

  8. #8
    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
    La validation des données et la construction des requêtes sont deux choses différentes.
    Si tu veux faire une validation, il faut la faire avant d'essayer de les utiliser. Par exemple, si tes données viennent d'un formulaire, tu fais un contrôle des données à la réception du formulaire, et ensuite seulement tu fais tes requêtes avec.
    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]

Discussions similaires

  1. Réponses: 1
    Dernier message: 13/04/2015, 11h17
  2. Réponses: 15
    Dernier message: 26/01/2015, 19h37
  3. [XL-2002] Macro de comparaison d'une cellule d'une feuille avec une cellule d'une autre feuille.
    Par steelydan dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/09/2010, 12h59
  4. Réponses: 4
    Dernier message: 15/10/2009, 13h33
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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