PHP的全局错误处理详解_PHP
本文目的
PHP的全局错误处理,在开发项目的时候很有用,可以帮助开发者快速定位一些问题,提高工作效率。默认情况下,全局错误会直接输出,但是最近开发时使用的一个框架库对全局错误处理进行了设定,导致很多错误信息没有输出,在定位问题上有一定的耗时。所以,研究了一下此库的实现,发现它设定了error_reporting和set_error_handler,导致此现象。现在记录一下这两个函数的用法,作为备忘录。
背景
PHP没有类型检测,开发人员比较容易输入错误单词,引起致命错误,最终导致脚本停止执行。如果这个时候,没有得到任何错误消息,那么会是一件很痛苦的事情。你不得不从脚本的第一行代码开始调试,在成千上万行的代码中不断的print或者echo,直到定位到这个输错的单词。然后,有不得不原路返回,将先前添加的print或echo全部删除。这时一件及其枯燥乏味的工作。
一般情况
正常情况下,php会将致命错误直接输出,会将错误的出处(文件地址,行号)和原因等输出,这样,开发着可以很方便的定位到问题。
但是有些时候,可能由于php.ini的设置问题,可能是第三方框架配置的问题,导致这些信息没有输出,那么此时,必须学会自己设置相关参数,输出这些错误信息,帮助快速定位问题。
error_reporting
error_reporting是一个php的全局配置参数,在php.ini中。用于配置错误输出级别,参数是比特位,可以用来设置错误输出的级别,下面是从php.ini中copy出来的信息:
; error_reporting is a bit-field. Or each number up to get desired error ; reporting level ; E_ALL - All errors and warnings (doesn't include E_STRICT) ; E_ERROR - fatal run-time errors ; E_RECOVERABLE_ERROR - almost fatal run-time errors ; E_WARNING - run-time warnings (non-fatal errors) ; E_PARSE - compile-time parse errors ; E_NOTICE - run-time notices (these are warnings which often result ; from a bug in your code, but it's possible that it was ; intentional (e.g., using an uninitialized variable and ; relying on the fact it's automatically initialized to an ; empty string) ; E_STRICT - run-time notices, enable to have PHP suggest changes ; to your code which will ensure the best interoperability ; and forward compatibility of your code ; E_CORE_ERROR - fatal errors that occur during PHP's initial startup ; E_CORE_WARNING - warnings (non-fatal errors) that occur during PHP's ; initial startup ; E_COMPILE_ERROR - fatal compile-time errors ; E_COMPILE_WARNING - compile-time warnings (non-fatal errors) ; E_USER_ERROR - user-generated error message ; E_USER_WARNING - user-generated warning message ; E_USER_NOTICE - user-generated notice message ; ; Examples: ; ; - Show all errors, except for notices and coding standards warnings ; ;error_reporting = E_ALL & ~E_NOTICE ; ; - Show all errors, except for notices ; ;error_reporting = E_ALL & ~E_NOTICE | E_STRICT ; ; - Show only errors ; ;error_reporting = E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR ; ; - Show all errors except for notices and coding standards warnings ; error_reporting = E_ALL & ~E_NOTICE
默认情况下,php会输出所有错误信息,除了notice。同样,php标准函数中提供了名称相同的函数error_reporting(int $level),用于在php脚本中,完成同样的功能。这样将不会影响其他程序。值得注意的是,$level为0的时候是关闭错误输出,也就是任何错误都不会输出。
set_error_handler
php的默认错误处理是将消息输出。但是,有时候需要定义一些其他操作,这时就需要自定义错误处理函数。php提供内置函数set_error_handler可以帮助我们注册自己的错误处理函数。函数原型如下:
mixed set_error_handler ( callback $error_handler [, int $error_types = E_ALL | E_STRICT ] )
值得注意的是,即使注册了错误处理函数,默认的行为仍然会执行,也就是错误出现时,仍然会输出错误信息,所以需要在程序中显示的将错误级别设置为0,然后在注册自己的的错误处理函数。这种方式,在生产环境下,尤其重要,因为即时出错,敏感内部错误信息也不会暴露给潜在的恶意用户。还有很重要的一点需要指出,自定义错误处理函数不能处理fatal error(比如编译错误)。下面是一个使用自定义错误处理函数的列子:
<?php error_reporting (0); function error_handler ($error_level, $error_message, $file, $line) { $EXIT = FALSE; switch ($error_level) { case E_NOTICE: case E_USER_NOTICE: $error_type = 'Notice'; break; case E_WARNING: case E_USER_WARNING: $error_type = 'Warning'; break; case E_ERROR: case E_USER_ERROR: $error_type = 'Fatal Error'; $EXIT = TRUE; break; default: $error_type = 'Unknown'; $EXIT = TRUE; break; } printf ("%s: %s in %s on line %d\n", $error_type, $error_message, $file, $line); if ($EXIT) { die(); } } set_error_handler ('error_handler'); //new NonExist(); echo $novar; echo 3/0; trigger_error ('Trigger a fatal error', E_USER_ERROR); new NonExist(); ?>
执行此脚本可以得到下面的输出:
Notice: Undefined variable: novar in /your/php_demo_file.php on line 40 Warning: Division by zero in /your/php_demo_file.php on line 41 Fatal Error: Trigger a fatal error in /your/php_demo_file.php on line 42
可以看到,最后的“new NoExistClass()”的异常,没有被自定义的错误处理函数捕获。
最后,捎带提一下,set_exception_handler注册顶层的异常处理,在web一用中,可以设定一下,然后统一的跳转到错误处理页面。

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PHP est un langage de programmation côté serveur largement utilisé qui offre des fonctionnalités puissantes et dynamiques aux sites Web. Cependant, dans la pratique, les développeurs peuvent rencontrer une grande variété d’erreurs et d’exceptions. L'une des erreurs courantes est PHPFatalerror:Uncaughtexception'Exception'. Dans cet article, nous explorerons les causes de cette erreur et comment y remédier. Le concept d'exception En PHP, l'exception fait référence à la situation inattendue rencontrée lors de l'exécution du programme, entraînant

Conseils de gestion des exceptions PHP : Comment utiliser les blocs try...catch pour intercepter et gérer plusieurs exceptions Introduction : Dans le développement d'applications PHP, la gestion des exceptions est une partie très importante. Lorsqu'une erreur ou une exception se produit dans le code, une gestion raisonnable des exceptions peut améliorer la robustesse et la fiabilité du programme. Cet article explique comment utiliser le bloc try...catch pour capturer et gérer plusieurs exceptions, aidant ainsi les développeurs à effectuer une gestion des exceptions plus flexible et plus efficace. Introduction à la gestion des exceptions Les exceptions font référence à des erreurs ou à des situations spéciales qui se produisent lors de l'exécution d'un programme. Lorsqu'une exception se produit

Lors de l'écriture de code PHP, la gestion des exceptions fait partie intégrante de la rendre plus robuste et maintenable. Cependant, la gestion des exceptions doit également être utilisée avec prudence, sinon elle pourrait entraîner davantage de problèmes. Dans cet article, je partagerai quelques bonnes pratiques en matière de classification des exceptions dans les programmes PHP afin de vous aider à mieux utiliser la gestion des exceptions afin d'améliorer la qualité du code. La notion d'exception En PHP, une exception fait référence à une erreur ou à une situation inattendue qui survient lors de l'exécution du programme. En règle générale, les exceptions entraînent l'arrêt du programme et génèrent un message d'exception.

En PHP, la gestion des exceptions est réalisée grâce aux mots clés d'essai, de catch, enfin et de lancement. 1) Le bloc d'essai entoure le code qui peut lancer des exceptions; 2) Le bloc de capture gère les exceptions; 3) Enfin, Block garantit que le code est toujours exécuté; 4) Le lancer est utilisé pour lancer manuellement les exceptions. Ces mécanismes aident à améliorer la robustesse et la maintenabilité de votre code.

Comment utiliser le mécanisme de gestion des exceptions et de tolérance aux pannes de PHP ? Introduction : Dans la programmation PHP, les mécanismes de gestion des exceptions et de tolérance aux pannes sont très importants. Lorsque des erreurs ou des exceptions se produisent lors de l'exécution du code, la gestion des exceptions peut être utilisée pour capturer et gérer ces erreurs afin de garantir la stabilité et la fiabilité du programme. Cet article explique comment utiliser le mécanisme de gestion des exceptions et de tolérance aux pannes de PHP. 1. Connaissance de base de la gestion des exceptions : Qu'est-ce qu'une exception ? Les exceptions sont des erreurs ou des conditions anormales qui se produisent lors de l'exécution du code, notamment des erreurs de syntaxe, des erreurs d'exécution, des erreurs logiques, etc. Quand différent

Comment implémenter la gestion globale des exceptions dans le développement de fonctions backend PHP ? Dans le développement back-end PHP, la gestion des exceptions est un élément très important. Cela peut nous aider à détecter les erreurs dans le programme et à les gérer de manière appropriée, améliorant ainsi la stabilité et les performances du système. Cet article présentera comment implémenter la gestion globale des exceptions dans le développement de fonctions back-end PHP et fournira des exemples de code correspondants. PHP fournit un mécanisme de gestion des exceptions. Nous pouvons intercepter les exceptions et les gérer en conséquence via les mots-clés try et catch. La gestion globale des exceptions fait référence à tous

À mesure que l’utilisation des API devient de plus en plus répandue, nous devons également prendre en compte les stratégies d’exception de données et de gestion des erreurs lors du développement et de l’utilisation des API. Cet article explorera comment PHP gère ces problèmes lors de l'implémentation des API. 1. Gestion des anomalies de données Les anomalies de données peuvent avoir de nombreuses raisons, telles que des erreurs de saisie utilisateur, des erreurs de transmission réseau, des erreurs de serveur interne, etc. Lors du développement en PHP, nous pouvons utiliser les méthodes suivantes pour gérer les exceptions de données. Renvoie le code d'état HTTP approprié Le protocole HTTP définit de nombreux codes d'état qui peuvent nous aider.

Exception de traitement du temps PHP : erreur lors du retour de l'heure, des exemples de code spécifiques sont nécessaires dans le développement Web, le traitement du temps est une exigence très courante. En tant que langage de script côté serveur couramment utilisé, PHP offre une multitude de fonctions et de méthodes de traitement du temps. Cependant, dans les applications pratiques, vous rencontrez parfois des situations anormales dans lesquelles le temps de retour est erroné, ce qui peut être dû à des erreurs dans le code ou à une mauvaise utilisation. Dans cet article, nous présenterons quelques situations courantes pouvant provoquer des erreurs de temps de retour et fournirons des exemples de code spécifiques pour aider les lecteurs à mieux comprendre
