php如何屏蔽错误提示
时间:2021-07-15 20:02
方法:1、使用错误控制运算符“@”,将其放置在一个PHP表达式前,则可能产生的错误信息都将被忽略掉。2、使用error_reporting()函数;3、在“php.ini”文件中,将“display_errors”项的值设置为“Off”。 本教程操作环境:windows7系统、PHP7.1版,DELL G3电脑 PHP 有 3 种屏蔽错误的方法: 使用错误控制运算符: 使用 error_reporting() 函数屏蔽错误 通过 display_errors 参数屏蔽错误 1、使用错误控制运算符: PHP 支持使用错误控制运算符 如果用 set_error_handler() 设定了自定义的错误处理函数,这个错误处理函数仍然会被调用,而如果在出错语句前使用了 需要注意的是, 【示例】使用 运行结果如下: 2、使用 PHP 有诸多错误级别,使用 error_reporting() 函数可以设置 PHP 会报告何种错误,函数的语法格式如下: 其中参数 $level 为设置错误级别,如果将 $level 设置为 0,将关闭所有 PHP 错误报告;如果设置为 -1,将返回所有的错误报告。 PHP 中的错误类型如下表所示: 【示例】使用 error_reporting() 函数屏蔽代码中的错误。 3、通过 这种方法应该是最彻底的一种解决办法,因为前两种方法只能作用于单行或者单个文件,而这个则是作用于所有的 PHP 文件。 具体的操作方法就是,打开 php.ini 配置文件,在其中搜索 display_errors,然后将 display_errors 的值设置为 Off 即可关闭所有的 PHP 错误报告。如下所示: 推荐学习:《PHP视频教程》 以上就是php如何屏蔽错误提示的详细内容,更多请关注www.gxlsystem.com其它相关文章!@
@
@
。将其放置在一个 PHP 表达式之前,该表达式可能产生的任何错误信息都将被忽略掉。@
的话,错误处理函数将返回 0。@
运算符只对表达式有效。简单来说就是,如果能从某处得到值,就能在它前面加上 @
运算符。例如可以在变量、函数、include 调用、常量等等之前使用 @
运算符,但不能把它放在函数或类的定义之前,也不能用于条件结构例如 if 和 foreach 等语句前。@
运算符对于可以导致程序终止的严重错误也是有效的,这意味着如果在某个不存在或者敲错了字母的函数调用前用了@来抑制错误信息,那么程序将没有任何提示的死在那里。@
错误控制运算符屏蔽代码中的错误。<?php
$link = @mysqli_connect("127.0.0.1", "my_user", "my_password", "my_db") or die('数据库连接失败!');
?>
数据库连接失败!
error_reporting()
函数屏蔽错误error_reporting([int $level])
值 常量 说明 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 除外的所有错误和警告信息。 <?php
error_reporting(0);
$link = mysqli_connect("127.0.0.1", "my_user", "my_password", "my_db") or die('数据库连接失败!');
?>
display_errors
参数屏蔽错误; 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