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 :

Afficher les erreurs php sur un portable de dev


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Homme Profil pro
    Architecte réseau
    Inscrit en
    Août 2018
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Architecte réseau

    Informations forums :
    Inscription : Août 2018
    Messages : 40
    Points : 44
    Points
    44
    Par défaut Afficher les erreurs php sur un portable de dev
    bonsoir,
    J'utilise actuellement un pc avec Ubuntu 23.04 sur lequel je veux faire du dev PHP.
    a chaque erreur PHP, apache me retourne une erreur 500.
    J'aimerais avoir les erreurs PHP a la place.
    j'ai donc configurer le fichier "/etc/php/8.1/apache2/php.ini"
    avec "display_errors = On" mais j ai toujours des erreurs 500.

    j'ai essayé avec un htaccess mais , la aussi impossible d'avoir les erreurs PHP.

    si qqun a déja résolu ce problème , ou si qqun a une idée je suis preneur ;-)

  2. #2
    Membre éclairé
    Homme Profil pro
    Autre
    Inscrit en
    Juillet 2021
    Messages
    364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Autre

    Informations forums :
    Inscription : Juillet 2021
    Messages : 364
    Points : 741
    Points
    741
    Par défaut
    Bonjour,

    Crée à la racine de ton site local un fichier phpinfo.php avec uniquement un appel de la fonction phpinfo() comme sur l'exemple de la doc : https://www.php.net/manual/fr/function.phpinfo.php
    Entre l'url de ce fichier dans ton navigateur http://localhost/phpinfo.php pour voir la configuration php utilisée par Apache.

    Regarde la ligne Loaded Configuration File qui indique le fichier de configuration php pour vérifier que tu modifies le bon fichier php.ini
    Si tu modifies le bon fichier, vérifie via la page phpinfo que la modification des autres directives est bien prise en compte (et penser à redémarrer le serveur apache à chaque modification de la configuration) :
    error_reporting = E_ALL
    display_errors = On

  3. #3
    Membre expert
    Avatar de cavo789
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2004
    Messages
    1 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 793
    Points : 3 064
    Points
    3 064
    Par défaut
    Citation Envoyé par saveus Voir le message
    bonsoir,
    J'utilise actuellement un pc avec Ubuntu 23.04 sur lequel je veux faire du dev PHP.
    a chaque erreur PHP, apache me retourne une erreur 500.
    J'aimerais avoir les erreurs PHP a la place.
    j'ai donc configurer le fichier "/etc/php/8.1/apache2/php.ini"
    avec "display_errors = On" mais j ai toujours des erreurs 500.

    j'ai essayé avec un htaccess mais , la aussi impossible d'avoir les erreurs PHP.

    si qqun a déja résolu ce problème , ou si qqun a une idée je suis preneur ;-)
    Sauf si je dis une bêtise, une erreur 500 ne permet pas d'avoir un affichage écran (c'est le serveur qui plante; erreur fatale). Il me semble qu'il n'y a pas de retour d'un contenu au client.

    Une erreur 500 est toutefois écrite dans le fichier error_log; tel que configuré.

  4. #4
    Membre éclairé
    Homme Profil pro
    Autre
    Inscrit en
    Juillet 2021
    Messages
    364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Autre

    Informations forums :
    Inscription : Juillet 2021
    Messages : 364
    Points : 741
    Points
    741
    Par défaut
    En effet si l'erreur vient du serveur Apache, il faudra regarder le journal d'erreur du serveur web.

    Si l'erreur vient bien de PHP (une jolie Parse Error en cas d'erreur de syntaxe par exemple), le détail de l'erreur 500 devrait s'afficher dans le navigateur si l'affichage des erreurs php est bien activée.

  5. #5
    Membre du Club
    Homme Profil pro
    Architecte réseau
    Inscrit en
    Août 2018
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Architecte réseau

    Informations forums :
    Inscription : Août 2018
    Messages : 40
    Points : 44
    Points
    44
    Par défaut
    merci pour vos réponses mais je n'ai pas été assez clair je pense
    mon serveur apache se comporte comme un serveur de production , il retourne des erreurs 500 quelque-sois l'erreur PHP, a la place des habituelles erreurs PHP type : parse error , bla bla...
    les erreurs PHP sont par contre ,elles, bien écrite dans les logs d'apache.
    (Mais être obligé d'aller lire les fichiers de logs , c'est pas pratique sur un ordinateur de dev)

    et j ai déja vérifié que
    - le php.ini est bien le bon.
    - il n y as pas d erreur de syntaxe ou de doublon du "display_errors = On" dans le php.ini
    -j ai essayé avec ou sans espace entre le = ... etc etc...
    mais apache ne le prend tout simplement pas en compte
    dans un phpinfo , mon display_error reste désesperement sur off

  6. #6
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 420
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 420
    Points : 15 789
    Points
    15 789
    Par défaut
    le code php est exécuté en tant que module apache ou en tant que cgi ?

  7. #7
    Membre du Club
    Homme Profil pro
    Architecte réseau
    Inscrit en
    Août 2018
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Architecte réseau

    Informations forums :
    Inscription : Août 2018
    Messages : 40
    Points : 44
    Points
    44
    Par défaut
    Citation Envoyé par mathieu Voir le message
    le code php est exécuté en tant que module apache ou en tant que cgi ?
    je ne sais pas trop.

    dans phpinfo() il y as :
    GATEWAY_INTERFACE CGI/1.1
    je dirrais donc cgi



    voici le lien du phpinfo()

    https://savhome.fr.nf/test.php

  8. #8
    Membre expert
    Avatar de cavo789
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2004
    Messages
    1 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 793
    Points : 3 064
    Points
    3 064
    Par défaut
    La question de Matthieu était : lances-tu ton script PHP en ligne de commandes (=dans une console DOS / Linux) ou est-ce via une page web ? Puisque tu nous a posté un script web, je suppose que c'est donc une page web.

    Sur ta machine, tu n'aurais pas un fichier /etc/php/8.1/apache2/php.ini-development. Je développe toute la journée en local (en utilisant Docker) et je n'ai pas connaissance d'un PHP qui se "comporterait" comme en production. Je veux dire par là que, par défaut, il est en mode dev.

    Si tu as le fichier, exécute cp /etc/php/8.1/apache2/php.ini-development /etc/php/8.1/apache2/php.ini afin d'écraser ton actuel fichier par celui qui active le mode DEV.

  9. #9
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 420
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 420
    Points : 15 789
    Points
    15 789
    Par défaut
    c'est la ligne "Server API Apache 2.0 Handler" qui indique que vous utilisez php sous forme de module (comme sur mon ordinateur de dév qui n'a pas votre souci). dans le cas contraire, cette valeur contiendrait quelque chose comme "FPM/fastCGI".

    Citation Envoyé par saveus Voir le message
    - le php.ini est bien le bon.
    ...
    dans un phpinfo , mon display_error reste désesperement sur off
    je n'avais pas bien lu ce message et cela semble être un souci de configuration beaucoup plus compliqué si vous modifiez le fichier php.ini indiqué dans le phpinfo.

    essayez de mettre ce code dans le fichier test.php

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
     
    ini_set("display_errors", "on");
     
    echo $a; // devrait afficher Notice: Undefined variable: a in ...
     
     
    phpinfo();

  10. #10
    Membre du Club
    Homme Profil pro
    Architecte réseau
    Inscrit en
    Août 2018
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Architecte réseau

    Informations forums :
    Inscription : Août 2018
    Messages : 40
    Points : 44
    Points
    44
    Par défaut
    je viens de résoudre mon problème.
    il était situé entre la chaise et le clavier:
    j'avais activer le displayerror dans la rubrique "quick reference"
    alors que 500 lignes plus loin j en avait un autre dans la rubrique "log"
    j avait pourtant fait une recherche mais j ai du le rater ;-(

  11. #11
    Membre expert
    Avatar de cavo789
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2004
    Messages
    1 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 793
    Points : 3 064
    Points
    3 064
    Par défaut
    Le fameux pebkac a encore frappé 😉

  12. #12
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 641
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 641
    Points : 66 666
    Points
    66 666
    Billets dans le blog
    1
    Par défaut
    Peut-être une source d'inspiration ?
    https://blog.developpez.com/spacefro...p-sans-debuger

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

Discussions similaires

  1. [MySQL] Comment afficher les erreurs (php, mysqli) ?
    Par Raptor92 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 20/04/2018, 11h26
  2. [DEBUTANT] Comment afficher les erreurs ?
    Par ionix dans le forum Langage
    Réponses: 2
    Dernier message: 20/10/2006, 16h13
  3. [MySQL] erreur php sur un formulaire de mis à jour
    Par carmen256 dans le forum PHP & Base de données
    Réponses: 34
    Dernier message: 06/04/2006, 13h39
  4. récupérer les erreurs php dans des exceptions
    Par jeanvincent dans le forum Langage
    Réponses: 6
    Dernier message: 14/10/2005, 16h26
  5. [web] comment afficher les erreur d'un cgi
    Par chtiboss dans le forum Web
    Réponses: 6
    Dernier message: 24/12/2003, 11h22

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