Aller au menu - Aller au contenu

[Plan du site] Vous êtes ici --- > Le Site du Zéro > Les tutoriels > Officiels > Site Web > Un site dynamique avec PHP ! > Annexes > Au secours ! Mon script plante ! > Lecture du tutoriel

Au secours ! Mon script plante !

Avatar
Auteur : M@teo21
Note : 19 / 20 (8 votes)
Visualisations : 131 841

Plus d'informations Plus d'informations
Alors comme ça votre script ne marche pas, et PHP vous affiche des erreurs incompréhensibles ?
Aucun souci à vous faire : c'est tout à fait normal, on ne réussit jamais un script du premier coup (en tout cas, pas moi :p)

Il existe des milliers de messages d'erreurs qui peuvent survenir (ok, jusque-là rien de très rassurant), et je n'ai pas vraiment le temps de vous faire la liste complète... mais j'en connais déjà un bon paquet.
Dans cette annexe, nous passerons en revue les erreurs les plus courantes, nous verrons pourquoi ça plante et, bien entendu, comment régler le problème ;)
Sommaire du chapitre :
Icône du chapitre
Chapitre précédent Sommaire Chapitre suivant

Les erreurs les plus courantes

Je pense qu'il est facile de parler d'erreurs "courantes", car vous verrez que certaines erreurs reviennent plus souvent que d'autres.

Nous allons voir les erreurs suivantes, qui sont assez courantes :

Parse error



Si on devait dire qu'il existe UNE erreur de base, ça serait très certainement celle-là. Impossible de programmer en PHP sans y avoir droit un jour.
Le message d'erreur que vous obtenez ressemble à celui-ci :

Parse error: parse error in fichier.php on line 15

Ce message vous indique une erreur dans fichier.php à la ligne 15. Généralement, cela veut dire que votre problème se situe à la ligne 15, mais ce n'est pas toujours le cas (trop facile sinon ^^ )

Si vous écrivez votre code PHP sous bloc-notes, faites "Affichage / Barre d'état". Une barre d'état apparaîtra en bas de la fenêtre, en vous indiquant à quelle ligne se trouve votre curseur.
Le mieux reste quand même d'utiliser un éditeur spécialisé, comme Notepad++ ou Dreamweaver, qui affiche les numéros des lignes comme ceci :

Image utilisateur

Bon, concrètement qu'est-ce qu'un parse error ?
Un "parse error" est en fait une instruction PHP pas correctement écrite. Plusieurs choses peuvent causer cela :

Si on vous dit que l'erreur est à la ligne 15 et que vous ne voyez vraiment pas d'erreur à cette ligne, n'hésitez pas à chercher l'erreur à la ligne juste au-dessus, elle s'y trouve peut-être !

Undefined function



Une autre erreur assez classique : la fonction inconnue. Vous obtenez ce message d'erreur :

Fatal Error: Call to undefined function: fonction_inconnue() in fichier.php on line 27

Là, il faut comprendre que vous avez utilisé une fonction qui n'existe pas.

2 possibilités :

Une dernière chose : il se peut aussi que vous essayiez d'utiliser une fonction qui n'est pas disponible dans la version de PHP que vous avez.
Vérifiez dans le manuel (comme je vous l'ai appris dans l'annexe sur la documentation) dans quelles versions de PHP cette fonction est disponible.

Wrong parameter count



Si vous utilisez mal une fonction, vous aurez cette erreur :

Warning: Wrong parameter count for fonction() in fichier.php on line 112

Cela signifie que vous avez oublié des paramètres pour la fonction, ou même que vous en avez mis trop.
Comme je vous l'ai appris dans le chapitre sur la doc PHP, consultez le mode d'emploi de la fonction pour savoir combien de paramètres elle prend, et lesquels sont facultatifs.

Par exemple, la fonction fopen() requiert au minimum 2 paramètres : le premier pour le nom du fichier à ouvrir et le second pour le mode d'ouverture (en lecture seule, écriture etc...). Si vous ne mettez que le nom du fichier à ouvrir comme ceci :

$fichier = fopen("fichier.txt");

... vous aurez l'erreur "Wrong parameter count". Pensez donc à rajouter le paramètre qui manque, par exemple comme ceci :

$fichier = fopen("fichier.txt", "r");

Dans les versions les plus récentes de PHP, on vous dit même le nombre de paramètres que vous avez oublié dans le message d'erreur !

Traiter les erreurs SQL

Comme vous le savez, le langage SQL est un langage à part entière dont on se sert en PHP. S'il peut y avoir des erreurs en PHP, il peut aussi y avoir des erreurs en SQL !
Il se peut par exemple que votre requête soit mal écrite, que le nom de la table que vous voulez ouvrir n'existe pas etc etc... Bref, les erreurs possibles sont là encore nombreuses.

Toutefois, ce n'est pas MySQL qui vous dira qu'il y a une erreur, mais PHP. Et PHP n'est pas très bavard en ce qui concerne les erreurs SQL. Nous allons donc voir :
  1. Comment repérer une erreur SQL en PHP
  2. Comment faire parler PHP pour qu'il nous donne l'erreur SQL (de gré, ou de force :p)


Repérer l'erreur SQL en PHP


Lorsqu'il s'est produit une erreur SQL, cela peut se manifester en PHP de plusieurs manières :
Si vous avez donc l'erreur sur mysql_fetch_array(), vous savez que la requête n'a pas marché, mais vous n'avez pas l'erreur qui vous dit ce qu'il s'est passé.
Nous allons maintenant voir comment on peut remédier à cela ;)

Allez ! Crache le morceau !



Comme visiblement PHP n'a pas envie de nous donner l'erreur renvoyée par MySQL, on va le lui demander d'une autre manière.
C'est très facile à faire, mais vous ne pouviez pas deviner tous seuls :p

Repérez la requête qui foire selon vous (certainement celle juste avant le mysql_fetch_array), et demandez d'afficher l'erreur s'il y en a une, comme ceci :

mysql_query("SELECT * FROM table") or die(mysql_error());

Si la requête marche, aucune erreur ne sera affichée.
Si la requête plante, PHP arrêtera de générer la page et vous affichera l'erreur donnée par MySQL...

A partir de là, il va falloir vous débrouiller tous seuls, car les erreurs SQL sont assez nombreuses et je ne peux pas toutes les lister ^^
En général, MySQL vous dit "You have an error in your SQL syntax near 'truc'". A vous de bien relire votre requête SQL, l'erreur se trouve généralement près de l'endroit où on vous l'indique.

Quelques erreurs plus rares

Les erreurs PHP sont très variées, et je ne parle même pas des erreurs SQL. N'espérez pas donc que je vous fasse ici la liste des 3946 erreurs de PHP, j'en serais incapable (je ne les ai pas encore toutes eues, mais ça ne saurait tarder à l'allure où je vais :p)
Je vais vous montrer quelques erreurs un peu plus rares que "parse error", mais que vous rencontrerez probablement un jour. Si déjà je peux vous aider pour ces erreurs-là, ça sera bien ^^

Nous allons voir les erreurs :


Headers already sent by...



Voilà une erreur classique quand on travaille avec les sessions ou avec les cookies :

Cannot modify header information - headers already sent by ...

Que doit-on comprendre par là ?
Les headers sont des informations d'en-tête qui sont envoyées avant toute chose au navigateur du visiteur. Elles permettent de dire "Ce que tu vas recevoir est une page HTML", ou "Ce que tu vas recevoir est une image PNG", ou encore : "Inscris un cookie".
Toutes ces choses-là doivent être dites avant que le moindre code HTML ne soit envoyé. En PHP, la fonction qui permet d'envoyer des informations de headers s'appelle header(). On s'en est notamment servi dans le chapitre sur la librairie GD pour indiquer que l'on envoyait une image et non pas une page HTML.

Il y a d'autres fonctions qui envoient toutes seules des headers. C'est le cas de session_start() et de setcookie().

Ce que vous devez retenir, c'est que chacune des ces fonctions doit être utilisée au tout début de votre code PHP. Il ne faut RIEN mettre avant, sinon ça provoquera l'erreur "Headers already sent by...".

Un exemple de code qui génère l'erreur :

<html>
<? session_start(); ?>


Ici, j'ai eu le malheur de mettre un peu de code HTML avant le session_start(), et c'est ce qui a provoqué l'erreur. Mettez le session_start() en tout premier, et vous n'aurez plus de problème ^^

<? session_start(); ?>
<html>


L'image contient des erreurs



C'est le navigateur qui vous donne ce message d'erreur et non pas PHP.
Ce message survient lorsque vous travaillez avec la librairie GD. Si vous avez fait une erreur dans votre code (par exemple un banal "parse error"), cette erreur sera inscrite dans l'image. Du coup, l'image ne sera pas valide et le navigateur ne pourra pas l'afficher.

Bon d'accord, l'erreur est dans l'image. Mais comment faire pour faire "apparaître" l'erreur ?


2 possibilités :

Dans les deux cas, vous verrez le message d'erreur apparaître. A partir de là, il ne vous restera plus qu'à corriger le bug !

Maximum execution time exceeded



Ca c'est le genre d'erreur qui arrive le plus souvent à cause d'une boucle interminable :

Fatal error: Maximum execution time exceeded in fichier.php on line 57

Imaginez que vous fassiez une boucle while, mais que celle-ci ne s'arrête jamais : votre script PHP va tourner en boucle tout le temps sans jamais s'arrêter.
Heureusement, PHP limite le temps d'exécution d'une page PHP à 30 secondes par défaut. Si une page met plus de 30s à se générer, PHP arrête tout en disant que c'est trop long. Et il fait bien, parce que sinon cela pourrait ralentir tout le serveur et rendre votre site inacessible !

Voici un exemple de boucle while qui ne s'arrêtera jamais :
Code : PHP
1
2
3
4
5
$nombre = 5;
while ($nombre == 5)
{
echo 'Zér0 ';
}


Comme vous pouvez le voir, un tel code PHP ne s'arrêtera jamais parce que $nombre vaut TOUJOURS 5...

Si vous avez donc l'erreur "Maximum execution time exceeded", il va falloir repérer une boucle qui ne s'arrête jamais, c'est elle qui provoque ce problème.

Rassurez-vous : la limite est fixée à 30s, mais vous n'y serez jamais confronté. En général, une bonne page PHP met environ 50 millisecondes à se charger (on est très loin des 30 secondes !).

Cette annexe touche à sa fin, j'espère que les informations que vous y aurez déniché vous auront aidé à résoudre vos problèmes.
Quoiqu'il en soit, n'oubliez pas que chaque problème est particulier. Un peu de persévérance et on finit toujours par trouver le bug.

Enfin, si vous n'y arrivez vraiment pas, ne baissez pas les bras pour autant et allez poser votre question sur les forums du site. Un Zér0 un peu plus expérimenté verra probablement votre erreur au premier coup d'oeil ;)
Chapitre précédent Sommaire Chapitre suivant
Retour en haut Retour en haut


Créé : le 19/07/2005 à 23:21:44
Modifié : le 08/09/2008 à 18:47:08
Avancement : 100%
Licence : Copie non autorisée

12 commentaires

Changer de design | En savoir plus | Plan du site | Politique d'accessibilité | Règles | RSS tutoriels | RSS news
Édité par Simple IT SARL : Nous contacter | Notre blog | Revue de presse | Publicité

Y'a plus rien à lire, faut remonter maintenant !

Hébergement web - Correction de tutoriels - Créer un site
Vous souhaitez apparaître ici ? Contactez-nous.

Nombre de connectés 132 Zéros connectés | Requêtes SQL 8 requêtes | Temps de génération de la page : Total (SQL) 0.0322s (0.018s)