
| auteur : Cyberzoide | Par exemple, vous avez l'erreur typique suivante : Parse error: parse error, expecting `T_STRING' in c:\program files\easyphp\www\monsite\mapage.php on line 17 |
(cette erreur ne survient pas avec les toutes dernières versions de PHP)
A cause d'un code du style suivant : echo "Ma valeur = $myObj->myValue <br>"; |
ou echo "Ma valeur = $myTab[$i] <br>"; |
Les variables incluses dans les chaînes délimitées par des doubles quotes " " sont interprétées par PHP, dans une certaine limite seulement. Dans le cas des variables comme "$i" ou "$foobar", PHP les interprète sans erreur. Mais dans le cas des variables complexes : tableau ou objet, il existe une ambiguïté dans la délimitation du nom de la variable. Par exemple "$tab[$i]" est interprété comme $tab et non pas comme $tab[$i] comme il le faudrait pourtant. Pour remédier à ce problème, il faut délimiter explicitement la totalité du nom de la variable grâce aux accolades {} : "${tab[$i]}" ou "{$tab[$i]}". Sinon, on peut aussi sortir la variable de la chaîne de caractères : "Ma valeur : ".$tab[$i]
Et pareil pour un objet : echo "Ma valeur : ${myObj->myValue}"; |
ou echo "Ma valeur : ".$myObj->myValue; |
|
| auteur : Jérôme | PHP dispose pour cela de la fonction error_reporting() qui modifie la directive error_reporting pendant l'exécution du script. PHP possède plusieurs niveaux d'erreurs, utiliser cette fonction configure ce niveau pendant l'exécution du script.
Pour cacher les erreurs à l'utilisateur, il est préférable de modifier le niveau d'error_reporting() à zéro pour les visiteurs et à E_ALL | E_STRICT pour les administrateurs
Vous pouvez obtenir la liste des constantes disponibles dans PHP sur cette page : Erreurs.
PS : Depuis PHP4 la configuration par défaut est E_ALL & ~E_NOTICE. C'est-à-dire que toutes les erreurs sauf les E_NOTICE sont affichées.
|
| auteurs : Forum PHP, Kerod |
L'arobase ( @)
est un opérateur de contrôle d'erreur, c'est-à-dire que
lorsqu'il est placé en préfixe d'une expression ou fonction
PHP, les messages d'erreur qui peuvent être générés par
cette expression ne seront pas affichés.
Toutefois, il est fortement conseillé de gérer les erreurs
plutôt que de les cacher ainsi. Pour ce faire, il faut
utiliser la fonction
error_reporting()
|
lien : Comment empêcher l'affichage des erreurs PHP ?
|
| auteur : Gruik | Beaucoup de fonctions retournent FALSE en cas d'échec. Alors vous serez peut-être amené à tester le retour à l'aide d'un if :
if ($f = fopen ("pouet.txt", "r")) {
} else {
} |
Cependant il est prévu en PHP un opérateur qui permet d'éxecuter une instruction si l'expression qui le précède est évaluée FAUX. Il s'agit de l'opérateur or. Exemple :
Une seule instruction est attendue apres l'opérateur or. Mais vous pouvez vous créer une fonction qui regroupera toutes les opérations que vous vouliez faire.
|
| auteur : BiD0uille | A l'utilisation des fonctions LDAP, PHP renvoie le message : Warning: LDAP: Compare operation could not be completed: No such object in [...] on line nn |
Cette erreur vient du fait que la chaîne qui précise le DN (qui signifie Distinguished Name) n'est pas bonne. Elle correspond à l'identifiant d'une entrée de l'annuaire LDAP et se doit d'être unique. Pour vérifier cela et spécifier un DN correct, il suffit d'utiliser un client LDAP comme JXplorer.
|
| auteur : Cyberzoide | Client does not support authentication protocol requested by server; consider upgrading MySQL client |
Cette erreur apparaît lorsque des clients MySQL d'une version inférieure à 4.1 tentent de se connecter à un serveur MySQL de version supérieure ou égale à 4.1.
Typiquement, l'extention MySQL de PHP, utilisée entre autres par phpMyAdmin, ne peut pas se connecter aux serveurs MySQL de version >= 4.1 en raison du changement du cryptage des mots de passe.
Pour y remédier, il existe deux solutions :
- Installer la nouvelle extension cliente MySQLi pour PHP
- Revenir à l'ancien cryptage dans votre serveur MySQL qui convertira tous les mots de passe via la commande :
UPDATE user SET PASSWORD = OLD_PASSWORD(PASSWORD); |
|
Consultez les autres F.A.Q's
Les sources présentés sur cette pages sont libre de droits,
et vous pouvez les utiliser à votre convenance. Par contre cette page de présentation de ces sources constitue une oeuvre intellectuelle protégée par les droits d'auteurs.
Copyright ©2003
Developpez LLC. Tout droits réservés Developpez LLC.
Aucune reproduction, même partielle, ne peut être faite de ce site et de
l'ensemble de son contenu : textes, documents et images sans l'autorisation
expresse de Developpez LLC. Sinon vous encourez selon la loi jusqu'à 3 ans
de prison et jusqu'à 300 000 E de dommages et intérets.
Cette page est déposée à la SACD.
|