Maison >développement back-end >Problème PHP >Comment bloquer les invites d'erreur en php
Méthode : 1. Utilisez l'opérateur de contrôle d'erreur "@" et placez-le devant une expression PHP, et tous les messages d'erreur pouvant être générés seront ignorés. 2. Utilisez la fonction error_reporting() ; 3. Dans le fichier "php.ini", définissez la valeur de l'élément "display_errors" sur "Off".
L'environnement d'exploitation de ce tutoriel : système Windows 7, PHP version 7.1, ordinateur DELL G3
PHP dispose de 3 façons de bloquer les erreurs :
Utiliser l'opérateur de contrôle d'erreur : @
Utilisez la fonction error_reporting() pour masquer les erreurs
Masquez les erreurs via le paramètre display_errors
1. Utiliser les opérateurs de contrôle d'erreur : @
PHP prend en charge l'utilisation d'opérateurs de contrôle d'erreur@
. Placez-le avant une expression PHP et tous les messages d'erreur que l'expression peut produire seront ignorés.
Si une fonction de gestion des erreurs personnalisée est définie avec set_error_handler(), cette fonction de gestion des erreurs sera toujours appelée, et si @
est utilisée avant l'instruction d'erreur, la fonction de gestion des erreurs renverra 0.
Il est à noter que l'opérateur @
n'est valable que pour les expressions. En termes simples, si vous pouvez obtenir une valeur quelque part, vous pouvez ajouter l'opérateur @
devant. Par exemple, l'opérateur @
peut être utilisé avant des variables, des fonctions, des appels d'inclusion, des constantes, etc., mais il ne peut pas être placé avant la définition d'une fonction ou d'une classe, ni avant des structures conditionnelles telles que les instructions if et foreach. . L'opérateur
@
est également efficace pour les erreurs graves pouvant entraîner la fin du programme. Cela signifie que si vous utilisez @ pour supprimer le message d'erreur avant un appel de fonction qui n'existe pas ou qui contient une lettre incorrecte, le programme ne vous demandera pas. toi. Meurs là.
[Exemple] Utilisez l'opérateur de contrôle d'erreur @
pour masquer les erreurs dans le code.
<?php $link = @mysqli_connect("127.0.0.1", "my_user", "my_password", "my_db") or die('数据库连接失败!'); ?>
Les résultats d'exécution sont les suivants :
数据库连接失败!
2. Utilisez la fonction error_reporting()
pour protéger les erreurs
PHP a de nombreux niveaux d'erreur. Utilisez la fonction error_reporting() pour définir le type d'erreurs que PHP signalera. le format de la fonction est le suivant :
error_reporting([int $level])
Le paramètre $level sert à définir le niveau d'erreur. Si $level est défini sur 0, tous les rapports d'erreurs PHP seront désactivés s'il est défini sur -1, tous les rapports d'erreurs ; sera restitué.
Les types d'erreurs en PHP sont indiqués dans le tableau ci-dessous :
值 | 常量 | 说明 |
---|---|---|
1 | E_ERROR | 致命的运行时错误,一般是不可恢复的情况,例如内存分配导致的问题,后果是导致脚本终止、不再继续运行。 |
2 | E_WARNING | 运行时警告(非致命错误),仅给出提示信息,但是脚本不会终止运行。 |
4 | E_PARSE | 编译时语法解析错误,仅由分析器产生。 |
8 | E_NOTICE | 运行时通知,表示脚本遇到可能会表现为错误的情况,但是在可以正常运行的脚本里面也可能会有类似的通知。 |
16 | E_CORE_ERROR | 在 PHP 初始化启动过程中发生的致命错误,类似 E_ERROR,但是是由 PHP 引擎核心产生的。 |
32 | E_CORE_WARNING | PHP 初始化启动过程中发生的警告(非致命错误),类似 E_WARNING ,但是是由 PHP 引擎核心产生的。 |
64 | E_COMPILE_ERROR | 致命编译时错误,类似 E_ERROR,但是是由 Zend 脚本引擎产生的。 |
128 | E_COMPILE_WARNING | 编译时警告(非致命错误),类似 E_WARNING,但是是由 Zend 脚本引擎产生的。 |
256 | E_USER_ERROR | 用户产生的错误信息,类似 E_ERROR,但是是由用户自己在代码中使用 PHP 函数 trigger_error() 来产生的。 |
512 | E_USER_WARNING | 用户产生的警告信息,类似 E_WARNING,但是是由用户自己在代码中使用 PHP 函数 trigger_error() 来产生的。 |
1024 | E_USER_NOTICE | 用户产生的通知信息,类似 E_NOTICE,但是是由用户自己在代码中使用 PHP 函数 trigger_error() 来产生的。 |
1024 | E_STRICT | 启用 PHP 对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。 |
2048 | E_RECOVERABLE_ERROR | 可被捕捉的致命错误,表示发生了一个可能非常危险的错误,但是还没有导致 PHP 引擎处于不稳定的状态。如果该错误没有被用户自定义句柄捕获,将成为一个 E_ERROR,从而使脚本终止运行。 |
8192 | E_DEPRECATED | 运行时通知,启用后将会对在未来版本中可能无法正常工作的代码给出警告。 |
16384 | E_USER_DEPRECATED | 用户产生的警告信息,类似 E_DEPRECATED,但是是由用户自己在代码中使用 PHP 函数 trigger_error() 来产生的。 |
30719 | E_ALL | E_STRICT 除外的所有错误和警告信息。 |
【示例】使用 error_reporting() 函数屏蔽代码中的错误。
<?php error_reporting(0); $link = mysqli_connect("127.0.0.1", "my_user", "my_password", "my_db") or die('数据库连接失败!'); ?>
3、通过 display_errors
参数屏蔽错误
这种方法应该是最彻底的一种解决办法,因为前两种方法只能作用于单行或者单个文件,而这个则是作用于所有的 PHP 文件。
具体的操作方法就是,打开 php.ini 配置文件,在其中搜索 display_errors,然后将 display_errors 的值设置为 Off 即可关闭所有的 PHP 错误报告。如下所示:
; This directive controls whether or not and where PHP will output errors, ; notices and warnings too. Error output is very useful during development, but ; it could be very dangerous in production environments. Depending on the code ; which is triggering the error, sensitive information could potentially leak ; out of your application such as database usernames and passwords or worse. ; For production environments, we recommend logging errors rather than ; sending them to STDOUT. ; Possible Values: ; Off = Do not display any errors ; stderr = Display errors to STDERR (affects only CGI/CLI binaries!) ; On or stdout = Display errors to STDOUT ; Default Value: On ; Development Value: On ; Production Value: Off ; http://php.net/display-errors display_errors = Off
推荐学习:《PHP视频教程》
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!