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 :

Validation sécurisation requête préparée [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2015
    Messages
    262
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2015
    Messages : 262
    Points : 121
    Points
    121
    Par défaut Validation sécurisation requête préparée
    Bonjour,

    j'aimerai vous soumettre mon script afin de faire valider la construction de ma requête préparée du point de vue de la sécurisation (contre tout type d'attaque).
    Elle fonctionne correctement mais je ne sais pas si je l'ai bien construire.

    je reçois une donnée depuis un formulaire qui propose une autocomplétion pour la recherche de pays via ajax.

    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
     
     
    <?php
     
     
    require_once "ConnectPDO.php"; 
     
     
    	$req = $_GET['q'];   
     
    	$sql = ("SELECT * FROM listpays WHERE nom_pays LIKE :req "); 
    	$stmt = $bdd->prepare($sql);
    	$stmt->bindValue(':req', ('%'.$req.'%'), PDO::PARAM_STR); 
    	$stmt->execute();
     
    	$array = array(); 
     
    	while($row = $stmt->fetch(PDO::FETCH_ASSOC)) 
    		{
    		    $array[] = $row['nom_pays']; 
    		}
     
    	echo json_encode($array);
    Merci pour vos retours.

  2. #2
    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 : 39
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    A priori, ta requête a l'air bien écrite sous réserve d'une connexion bien établie, de préférence en UTF-8 et avec l'émulation désactivée.

    Petite optimisation possible : si tu ne t'intéresse qu'à une seule colonne et que tu veux la récupérer dans un tableau, tu peux utiliser en utilisant fetchAll avec la configuration FETCH_COLUMN :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $sql = ("SELECT nom_pays FROM listpays WHERE nom_pays LIKE :req "); 
    $stmt = $bdd->prepare($sql);
    $stmt->bindValue(':req', ('%'.$req.'%'), PDO::PARAM_STR); 
    $stmt->execute();
    $array = $stmt->fetchAll(PDO::FETCH_COLUMN, 0);

    Petit rappel : le but des requêtes préparées n'est pas de sécuriser les requêtes, mais d'optimiser leur exécution. La sécurisation, via l'échappement des données, est un chouette effet de bord (mais ça marche quand même dans 99% des cas )
    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]

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2015
    Messages
    262
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2015
    Messages : 262
    Points : 121
    Points
    121
    Par défaut
    pour ton retour...j'ai en effet une seule colonne, je vais donc partir sur ton conseil

    En revanche :

    " sous réserve d'une connexion bien établie, de préférence en UTF-8 et avec l'émulation désactivée. " => du vrai charabia à ce jour pour moi voilà ce que j'ai fait simplement dans un fichier : "ConnectPDO.php"

    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
     
     
    <?php
     
     
    $dsn = 'mysql:host=127.0.0.1;dbname=test';
    $user = 'XXXXXXX';
    $password = 'xxxxxxx'; 
     
    	try {
    		    $bdd = new PDO($dsn, $user, $password);
    		} 
    	catch (PDOException $e)
    		{
    		    echo 'Connexion échouée : ' . $e->getMessage(). "<br/>";
    		    die();
    		}

  4. #4
    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 : 39
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Citation Envoyé par Celira Voir le message
    sous réserve d'une connexion bien établie, de préférence en UTF-8 et avec l'émulation désactivée.
    De préférence en UTF-8 : tu précises l'encodage utilisé par la connexion, histoire d'éviter les problèmes de caractères spéciaux, le standard étant UTF-8.
    Avec l'émulation désactivée : L'émulation des requêtes préparées fait que le pilote "fait semblant" de faire une requête préparée. En désactivant l'émulation, PDO fait appel au mécanisme natif de la base, ce qui est normalement meilleur (enfin d'après ce que j'ai compris, je dois avouer que ce point est un chouia flou pour moi)

    Au passage, tu n'as pas de gestion d'erreurs activée (par défaut PDO ne dit rien quand il rencontre une erreur et se contente de te planter plus loin lorsque tu essayes d'exploiter les résultats )

    Ta connexion devient donc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $dsn = 'mysql:host=127.0.0.1;dbname=test;charset=utf8';
    $user = 'XXXXXXX';
    $password = 'xxxxxxx'; 
    $pdo = new PDO($dsn, $user, $password, [
                PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
                PDO::ATTR_EMULATE_PREPARES   => false
                ]);
    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]

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bonjour,


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    	$stmt->bindValue(':req', ('%'.$req.'%'), PDO::PARAM_STR);
    Les parenthèses sont inutiles :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    	$stmt->bindValue(':req', '%'.$req.'%', PDO::PARAM_STR);
    Perso, j'utilise aussi bindValue, ce qui permet aussi de définir le type requis (PDO::PARAM_STR, PDO::PARAM_INT,...)


    @Celira

    Une discussion concernant ATTR_EMULATE_PREPARES

    Il semble qu'il soit à true par défaut.
    Si ça constituait une "faille" de sécurité, il serait à false par défaut, non ? (je me pose aussi pas question...)

  6. #6
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2015
    Messages
    262
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2015
    Messages : 262
    Points : 121
    Points
    121
    Par défaut
    merci pour vos retours,

    j'ai lu la discussion Une discussion concernant ATTR_EMULATE_PREPARES mais je n'ai pas tout compris....je garde néanmoins vos propositions de modifications.

  7. #7
    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 : 39
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Citation Envoyé par jreaux62 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    	$stmt->bindValue(':req', '%'.$req.'%', PDO::PARAM_STR);
    Perso, j'utilise aussi bindValue, ce qui permet aussi de définir le type requis (PDO::PARAM_STR, PDO::PARAM_INT,...)
    Perso je préfère bindParam, parce que ça permet de modifier la valeur de la donnée après avoir fait le bind : très pratique quand on appelle une requête d'insertion en boucle par exemple. Cependant : ça a l'inconvénient de risquer de ne pas avoir au moment de l'exécution la valeur qu'on pensait (l'inconvénient de l'avantage )
    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]

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

Discussions similaires

  1. [PDO] Requête préparée
    Par Yoshio dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 16/10/2007, 12h07
  2. [PDO] Requête préparée, retour d'erreur à masquer
    Par speedev dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 20/06/2007, 10h39
  3. [PDO] Problème de requête préparée (à n'y rien comprendre?)
    Par waldo2188 dans le forum Bibliothèques et frameworks
    Réponses: 3
    Dernier message: 20/03/2007, 21h53
  4. Valider une requête avec vk_return
    Par pierrot67 dans le forum Bases de données
    Réponses: 4
    Dernier message: 27/02/2007, 16h54
  5. [PDO] Ma requêtes préparées me retourne false
    Par jeff_! dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 03/05/2006, 22h07

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