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

Langage PHP Discussion :

Remonter à la source d'une erreur


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Inscrit en
    Novembre 2008
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 113
    Points : 73
    Points
    73
    Par défaut Remonter à la source d'une erreur
    Bonjour !

    Mes requêtes mySQL sont envoyées à une fonction, qui se charge de faire le mysql_query.

    Le problème, c'est que lorsque ça plante, le message d'erreur redirige vers la ligne de la fonction contenant l'appel à mysql query, et non à l'appel original à cette fonction. Pour peu qu'on appelle cette fonction trente fois dans un même fichier, il devient difficile de savoir où se situe l'erreur, sur quelle requête...

    Un plugin comme xdebug permet de tracer ces erreurs jusqu'à leur source, donnant le chemin jusqu'à l'erreur originale. Il se trouve que je ne peux pas installer xdebug sur la machine actuellement en utilisation.

    Sauriez-vous me dire comment se débrouille xdebug pour remonter à l'appel à la fonction qui a généré l'erreur ? Ou sinon, une autre méthode pour localiser l'appel coupable ?

    Merci !

  2. #2
    Expert éminent
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Points : 7 762
    Points
    7 762
    Par défaut
    Il y a deux façons de visualiser la pile d'appel:
    - soit utiliser les exceptions (la classe Exception porte une méthode getTrace)
    - soit utiliser la fonction debug_backtrace à l'endroit ou l'erreur est rencontrée

    E.G.
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    function a () {
    	return b();
    }
    function b () {
    	return c();
    }
    function c () {
    	return debug_backtrace();
    }
     
    var_dump( a() );

  3. #3
    Membre régulier
    Inscrit en
    Novembre 2008
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 113
    Points : 73
    Points
    73
    Par défaut
    Merci beaucoup... Pour la vitesse et la réponse parfaite.

    debug_backtrace fait le boulot, comme on dit.

    Résolu !

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

Discussions similaires

  1. Source d'une erreur "Descripteur non valide"
    Par Z4ng3tsu dans le forum C#
    Réponses: 4
    Dernier message: 17/02/2011, 12h17
  2. Concaténation, source d'une erreur de syntaxe
    Par kate59 dans le forum PHP & Base de données
    Réponses: 14
    Dernier message: 18/04/2008, 20h21
  3. Source du fichier plat : trop de ligne génère une erreur
    Par Monico dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 30/08/2007, 16h04
  4. Réponses: 6
    Dernier message: 16/07/2007, 17h11
  5. [VB6] Source D'une erreur
    Par krest dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 16/07/2003, 17h33

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