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 :

Message d'erreur qui apparaît


Sujet :

PHP & Base de données

  1. #1
    Membre éprouvé
    Inscrit en
    Mars 2004
    Messages
    1 931
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 1 931
    Par défaut Message d'erreur qui apparaît
    Bonjour à tous,

    je débute en requête PDO et j'aimerais savoir si la requête suivante va bien faire apparaître un message dans la cas où elle ne serait pas correcte :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $sqlm = $db("SELECT mail, nom, prenom, civilite FROM flatforswap_adherent WHERE id_adh=?");
    $reqm->execute(array($_SESSION["id_adh"]));
    $datam = $reqm->fetch();
    Ma connexion à la base de données se fait dans une page connexion.php qui contient le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    try{
    	$db = new PDO('mysql:dbname=bdd;host=localhost', 'user', 'mdp', array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION)););
    }
    catch (Exception $e){
            die('Erreur : ' . $e->getMessage());
    }

  2. #2
    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
    Ton code n'est de toute façon pas bon, tu as oublié le "prepare".
    Mais dans ton cas, l'id stocké dans une session est une donnée fiable (ou alors ton code est vraiment mal fichu), la requête n'a pas besoin d'être préparée.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $sqlm = $db->query("SELECT mail, nom, prenom, civilite FROM flatforswap_adherent WHERE id_adh=" . $_SESSION["id_adh"]);
    $datam = $reqm->fetch();
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre éprouvé
    Inscrit en
    Mars 2004
    Messages
    1 931
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 1 931
    Par défaut
    Bonjour Sabotage,

    au fait je n'ai pas envie de me poser à chaque fois la question si la donnée est fiable ou pas.
    Je veux préparer la totalité de mes requêtes afin de ne pas avoir de mauvaises surprises.
    Exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <?php
    $req = $bdd->prepare('SELECT nom FROM jeux_video WHERE possesseur = ? AND prix <= ?');
    $req->execute(array($_GET['possesseur'], $_GET['prix_max']));
    ?>
    Je sais que c'est une methode GET donc plus dangeureuse, mais mon but est de l'appliquer partout...

  4. #4
    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
    La meilleure façon de concevoir la sécurité est de réfléchir à tous les aspects du code.
    On voit malheureusement trop de personnes qui appliquent aveuglement des méthodes sans comprendre ce qu'elles font, et donc mal.
    On voit aussi malheureusement trop de personnes qui ne font rien. Tu peux préparer toutes les requêtes, cela demande seulement un peu plus de travail à mysql (ou à PHP si tu n'as pas désactivè l’émulation de la préparation).
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre éprouvé
    Inscrit en
    Mars 2004
    Messages
    1 931
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 1 931
    Par défaut
    bon, ben si je comprends bien je n'aurais pas de réponse à ma question concernant les message d'erreurs

    Et comment savoir quelle requêtes faut-il préparer et lesquelles il ne faut pas préparer ?

  6. #6
    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
    Je n'ai pas compris ta question. Si tu veux vérifier si l'exception se déclenche bien, provoque volontairement une erreur, tu auras la réponse tout de suite.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    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
    La réponse de Sabotage est logique et pour savoir si une requête doit être préparée, c'est le cas si elle utilise une variable dont la valeur peut être affectée par l'utilisateur. Mais tu peux effectivement les préparer systématiquement...

Discussions similaires

  1. [A-03] Message d'erreur qui ferme la base de données
    Par moilou2 dans le forum VBA Access
    Réponses: 6
    Dernier message: 23/10/2008, 16h26
  2. Message d'erreur qui s'affiche deux fois au lieu de trois
    Par popolvictory dans le forum Forms
    Réponses: 2
    Dernier message: 23/10/2008, 16h00
  3. message d'erreur qui bloque la mise à jour
    Par silence_r dans le forum Windows XP
    Réponses: 3
    Dernier message: 19/10/2008, 11h16
  4. si je saisie rien label un message d erreur qui sort
    Par dimainfo dans le forum Interfaces Graphiques en Java
    Réponses: 2
    Dernier message: 29/07/2007, 23h19
  5. Réponses: 2
    Dernier message: 29/05/2006, 12h43

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