php错误处理
错误类型
因为错误类型整型值的巧妙设定,可以采用按位运算符
1 E_ERROR (integer)
致命的运行时错误。这类错误一般是不可恢复的情况,例如内存分配导致的问题。
导致脚本终止不再继续运行
例子:调用一个未定义的函数,存在没有捕获的异常
2 E_WARNING (integer)
运行时警告 (非致命错误)
仅给出提示信息,但是脚本不会终止运行。
4 E_PARSE (integer)
编译时语法解析错误。
解析错误仅仅由分析器产生。
register_shutdown_function不能捕获到本文件内发生的这个错误
8 E_NOTICE (integer)
运行时通知。表示脚本遇到可能会表现为错误的情况,但是在可以正常运行的脚本里面也可能会有类似的通知
例子:使用未定义的变量
16 E_CORE_ERROR (integer)
在PHP初始化启动过程中发生的致命错误。
该错误类似 E_ERROR,但是是由PHP引擎核心产生的。
32 E_CORE_WARNING (integer)
PHP初始化启动过程中发生的警告 (非致命错误)
类似 E_WARNING,但是是由PHP引擎核心产生的
E_COMPILE_
编译相关
64 E_COMPILE_ERROR (integer)
致命编译时错误。类似E_ERROR, 但是是由Zend脚本引擎产生的。 since PHP 4
128 E_COMPILE_WARNING (integer)
编译时警告 (非致命错误)。类似 E_WARNING,但是是由Zend脚本引擎产生的。
E_USER_
用户产生的
256 E_USER_ERROR (integer)
用户产生的错误信息。类似 E_ERROR, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。 since PHP 4
512 E_USER_WARNING (integer)
用户产生的警告信息。类似 E_WARNING, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。 since PHP 4
1024 E_USER_NOTICE (integer)
用户产生的通知信息。类似 E_NOTICE, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的
2048 E_STRICT (integer)
启用 PHP 对代码的修改建议,以确保代码具有最佳的互操作性和向前兼容性。
4096 E_RECOVERABLE_ERROR (integer)
可被捕捉的致命错误。 它表示发生了一个可能非常危险的错误,但是还没有导致PHP引擎处于不稳定的状态。 如果该错误没有被用户自定义句柄捕获 ( set_error_handler()),将成为一个 E_ERROR 从而脚本会终止运行。
8192 E_DEPRECATED (integer)
运行时通知。
启用后将会对在未来版本中可能无法正常工作的代码给出警告。
16384 E_USER_DEPRECATED (integer)
用户产生的警告信息。 类似 E_DEPRECATED, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。
30719 E_ALL (integer)
E_STRICT出外的所有错误和警告信
错误处理相关函数
error_reporting
int error_reporting ([ int $level ] )
设置应该报告何种 PHP 错误
// 关闭所有PHP错误报告,会返回新的错误报告级别error_reporting(0);// Report simple running errorserror_reporting(E_ERROR | E_WARNING | E_PARSE);
如果不带参数就返回当前错误报告级别
error_get_last
获取最后发生的错误,register_shutdown_function()常常用到
array error_get_last ( void )
返回结果
Array(
[type] => 8
[message] => Undefined variable: a [file] => C:\WWW\index.php [line] => 2)
trigger_error
产生一个用户级别的 error/warning/notice 信息
bool trigger_error ( string $error_msg [, int $error_type = E_USER_NOTICE ]
error_log
把错误信息发送到 web 服务器的错误日志,或者到一个文件里,文件不存在时会创建
bool error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] )
message_type
设置错误应该发送到何处
0 message 发送到 PHP 的系统日志,使用操作系统的日志机制或者一个文件,取决于php.ini中 error_log 的设置。 这是个默认的选项。
1 message 发送到参数 destination 设置的邮件地址。 第四个参数 extra_headers 只有在这个类型里才会被用到。
2 不再是一个选项。
3 message 被发送到位置为 destination 的文件里。 字符 message 不会默认被当做新的一行。
4 message 直接发送到 SAPI 的日志处理程序
set_error_handler()
设置一个用户定义的错误处理函数来处理脚本中出现的错误
mixed set_error_handler ( callable $error_handler [, int $error_types = E_ALL | E_STRICT ] )
error_types 里指定的错误类型都会绕过 PHP 标准错误处理程序,除非回调函数返回了 FALSE 。error_reporting() 设置将不会起到作用而你的错误处理函数继续会被调用,在需要时你有责任使用 die()。
NOTE
以下级别的错误不能由用户定义的函数来处理: E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING,和在 调用 set_error_handler() 函数所在文件中产生的大多数 E_STRICT
error_handler
handler ( int $errorLevel , string $errorMessage [, string $errfile [, int $errline [, array $errcontext ]]] )
errcontext, 是一个指向错误发生时活动符号表的 array。 也就是说,errcontext 会包含错误触发处作用域内所有变量的数组。 用户的错误处理程序不应该修改错误上下文(context)。
set_exception_handler
设置一个用户定义的异常处理函数
getMessage(), "\n";}set_exception_handler('exception_handler');throw new Exception('Uncaught Exception');echo "Not Executed\n";?>
register_shutdown_function
这个函数是在脚本结束之后运行的函数(不管是正常结束还是通过exit、发生错误结束)
php.ini中有关错误的配置
php错误机制总结
error_reporting = E_ALL // 报告错误级别,什么级别的error_log = /tmp/php_errors.log // php中的错误显示的日志位置display_errors = On // 是否把错误展示在输出上,这个输出可能是页面,也可能是stdoutdisplay_startup_errors = On // 是否把启动过程的错误信息显示在页面上,记得上面说的有几个Core类型的错误是启动时候发生的,这个就是控制这些错误是否显示页面的。log_errors = On // 是否要记录错误日志log_errors_max_len = 1024 // 错误日志的最大长度ignore_repeated_errors = Off // 是否忽略重复的错误track_errors = Off // 是否使用全局变量$php_errormsg来记录最后一个错误xmlrpc_errors = 0 //是否使用XML-RPC的错误信息格式记录错误xmlrpc_error_number = 0 // 用作 XML-RPC faultCode 元素的值。html_errors = On // 是否把输出中的函数等信息变为HTML链接docref_root = http://manual/en/ // 如果html_errors开启了,这个链接的根路径是什么fastcgi.logging = 0 // 是否把php错误抛出到fastcgi中
PHP默认是会在日志和标准输出(如果是fpm模式标准输出就是页面)
error_reporting的参数是错误级别。表示什么样子的级别才应该触发错误
display_errors是控制是否要在标准输出展示错误信息
log_errors则是控制是否要在日志中记录错误信息
error_log是显示错误日志的位置
<br/>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

PHP是一种流行而强大的服务器端编程语言,可以用来开发各种Web应用程序。就像其他编程语言一样,PHP也有可能会出现错误和异常。这些错误和异常可能由各种原因引起,如程序错误、服务器错误、用户输入错误等等。为了确保程序的运行稳定性和可靠性,PHP提供了一套完整的错误处理机制。PHP错误处理机制的基本思想是:当发生错误时,程序会停止执行并输出一条错误消息。我们可

如何处理PHP中的语法错误引言:在开发PHP程序时,经常会遇到语法错误的情况。语法错误是由于代码违反了PHP语法规则所引起的,它会导致脚本无法正确执行。本文将介绍一些处理PHP语法错误的方法,并提供相应的代码示例。使用错误提示功能PHP提供了丰富的错误提示功能,在开发过程中可以打开这些提示,以便及时发现和解决语法错误。可以通过设置erro

PHP文件操作错误的处理方法及生成相应报错信息在使用PHP进行文件操作时,可能会遇到各种错误,如找不到文件、权限错误等。这些错误可能会导致程序无法正常运行,因此合理处理文件操作错误是非常重要的。本文将介绍PHP文件操作错误的处理方法,并展示如何生成相应的报错信息。一、错误处理方法使用错误控制运算符PHP提供了错误控制运算符“@”,可以在执行可能出错的语句前添

如何处理PHP文件路径错误并生成对应的报错信息在开发和维护PHP应用程序时,经常会遇到文件路径错误的情况。当引用一个不存在的文件或者指定了错误的路径时,在PHP中会抛出一个致命错误,导致应用程序无法正常运行。为了更好地调试和处理这种情况,我们可以通过以下方式来处理PHP文件路径错误,并生成对应的报错信息。使用绝对路径在引用文件时,尽量使用绝对路径而不是相对路

如何进行PHP后端功能开发的错误处理?作为一名PHP后端开发人员,在开发过程中,我们经常会遇到各种错误。良好的错误处理是保证系统稳定性和用户体验的重要因素。在本文中,我将分享一些如何进行PHP后端功能开发的错误处理的方法和技巧,并提供相应的代码示例。设置错误报告级别PHP提供了一个错误报告级别参数,可以通过设置来定义要报告的错误类型。使用error_repo

解决PHP报错:调用未定义的类方法在进行PHP开发过程中,经常会遇到调用未定义的类方法的报错。这种情况一般是由于代码编写不规范或者使用的类方法不存在而导致的。下面我们将介绍一些解决该问题的常见方法。检查类方法是否存在当报错提示调用未定义的类方法时,首先要检查该方法是否存在于对应的类中。通过使用method_exists()函数可以检查某个类是否存在某个方法。

PHP错误处理:最佳实践和建议在编写PHP代码时,错误处理是一项非常重要的任务。如果不正确地处理错误,就会导致应用程序中的漏洞和安全问题。同时,良好的错误处理还有助于提高代码的可维护性和可扩展性。本文将介绍一些PHP错误处理的最佳实践和建议,并提供一些代码示例。使用异常处理在PHP中,异常是一种用于处理运行时错误的机制。通过使用异常,可以将错误

处理PHP源代码中index报错的方法在PHP开发过程中,经常会遇到"indexundefined"的报错。这种报错通常是由于尝试访问数组或对象中不存在的索引而引起的。解决这种问题的方法有很多种,以下将结合具体的代码示例来展示几种处理的方法。方法一:使用isset()函数isset()函数用于检查变量是否已经被声明以及是否有值。通过使用isset()函数,
