菜单
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

PHP 教程

PHP HOME PHP 简介 PHP 安装 PHP 语法 PHP 注释 PHP 变量 PHP Echo / Print PHP 数据类型 PHP 字符串 PHP 数字 PHP 类型转换 PHP 数学 PHP 常量 PHP 魔术常量 PHP 运算符 PHP If...Else...Elseif PHP Switch PHP 循环 PHP 函数 PHP 数组 PHP 超全局变量 PHP 正则表达式

PHP 表单

PHP 表单处理 PHP 表单验证 PHP 表单必填项 PHP 表单 URL/电子邮件 PHP 表单完成

PHP 高级

PHP 日期和时间 PHP Include PHP 文件处理 PHP 文件打开/读取 PHP 文件创建/写入 PHP 文件上传 PHP Cookies PHP Sessions PHP 过滤器 PHP 高级过滤器 PHP 回调函数 PHP JSON PHP 异常

PHP OOP

PHP 什么是 OOP PHP 类/对象 PHP 构造函数 PHP 析构函数 PHP 访问修饰符 PHP 继承 PHP 常量 PHP 抽象类 PHP 接口 PHP Trait PHP 静态方法 PHP 静态属性 PHP 命名空间 PHP 可迭代对象

MySQL 数据库

MySQL 数据库 MySQL 连接 MySQL 创建数据库 MySQL 创建表 MySQL 插入数据 MySQL 获取最后 ID MySQL 插入多条数据 MySQL 预处理 MySQL 查询数据 MySQL Where MySQL Order By MySQL 删除数据 MySQL 更新数据 MySQL 限制数据

PHP XML

PHP XML 解析器 PHP SimpleXML 解析器 PHP SimpleXML - 获取 PHP XML Expat PHP XML DOM

PHP - AJAX

AJAX 简介 AJAX PHP AJAX 数据库 AJAX XML AJAX 实时搜索 AJAX 投票

PHP 示例

PHP 示例 PHP 编译器 PHP 测验 PHP 练习 PHP 服务器 PHP 证书

PHP 参考手册

PHP 概述 PHP 数组 PHP 日历 PHP 日期 PHP 目录 PHP 错误 PHP 异常 PHP 文件系统 PHP 过滤器 PHP FTP PHP JSON PHP 关键词 PHP Libxml PHP 邮件 PHP 数学 PHP 杂项 PHP MySQLi PHP 网络 PHP 输出控制 PHP 正则表达式 PHP SimpleXML PHP Stream PHP String PHP 变量处理 PHP XML 解析器 PHP 压缩 PHP 时区

PHP 错误 函数


PHP 错误简介

错误处理函数用于处理错误处理和日志记录。

错误处理函数允许我们定义自己的错误处理规则,并修改错误的记录方式。

日志函数允许我们将消息直接发送到其他机器、电子邮件或系统日志。

错误报告函数允许我们自定义错误反馈的级别和类型。


安装

PHP 错误函数是 PHP 核心的一部分。无需安装即可使用这些函数。


运行时配置

错误函数的行为受 php.ini 中设置的影响。

错误和日志记录配置选项

名称 默认值 描述 可更改
error_reporting NULL 设置错误报告级别(可以是整数或命名常量) PHP_INI_ALL
display_errors "1" 指定错误是打印到屏幕,还是隐藏起来。
注意: 此功能绝不应在生产环境中使用(仅用于支持您的开发)
PHP_INI_ALL
display_startup_errors "0" 即使 display_errors 为开启状态,在 PHP 启动过程中发生的错误也不会显示
注意: 强烈建议关闭 display_startup_errors,除非是为了调试
PHP_INI_ALL
log_errors "0" 定义脚本错误消息是否应记录到服务器的错误日志或 error_log。
注意: 在生产网站上,强烈建议使用错误日志记录而不是错误显示
PHP_INI_ALL
log_errors_max_len "1024" 设置 log_errors 的最大长度(字节)。值“0”表示不设置任何最大长度。此长度适用于已记录的错误、已显示的错误以及 $php_errormsg(PHP 4.3 起可用) PHP_INI_ALL
ignore_repeated_errors "0" 指定是否记录重复的错误消息。设置为“1”时,它将不会记录来自同一文件同一行的重复错误(PHP 4.3 起可用) PHP_INI_ALL
ignore_repeated_source "0" 指定是否记录重复的错误消息。设置为“1”时,它将不会记录来自不同文件或源行的重复错误(PHP 4.3 起可用) PHP_INI_ALL
report_memleaks "1" 如果设置为“1”(默认值),此参数将显示 Zend 内存管理器检测到的内存泄漏报告(PHP 4.3 起可用) PHP_INI_ALL
track_errors "0" 如果设置为“1”,则最后一个错误消息将始终存在于变量 $php_errormsg 中 PHP_INI_ALL
html_errors "1" 关闭错误消息中的 HTML 标签 PHP_INI_ALL
PHP_INI_SYSTEM 在 PHP <= 4.2.3 中。
xmlrpc_errors "0" 关闭正常错误报告,并将错误格式化为 XML-RPC 错误消息(PHP 4.1 起可用) PHP_INI_SYSTEM
xmlrpc_error_number "0" 用作 XML-RPC faultCode 元素的值(PHP 4.1 起可用) PHP_INI_ALL
docref_root "" (PHP 4.3 起可用) PHP_INI_ALL
docref_ext "" (PHP 4.3.2 起可用) PHP_INI_ALL
error_prepend_string NULL 指定在错误消息之前输出的字符串 PHP_INI_ALL
error_append_string NULL 指定在错误消息之后输出的字符串 PHP_INI_ALL
error_log NULL 指定脚本错误应记录到的文件名。该文件应可由 Web 服务器的用户写入。如果使用特殊值 syslog,错误将发送到系统日志 PHP_INI_ALL


PHP 错误和日志记录函数

函数 描述
debug_backtrace() 生成回溯信息
debug_print_backtrace() 打印回溯信息
error_clear_last() 清除最后发生的错误
error_get_last() 返回最后发生的错误
error_log() 将错误消息发送到日志、文件或邮箱
error_reporting() 指定报告哪些错误
restore_error_handler() 恢复先前的错误处理程序
restore_exception_handler() 恢复先前的异常处理程序
set_error_handler() 设置用户定义的错误处理函数
set_exception_handler() 设置用户定义的异常处理函数
trigger_error() 创建用户级别的错误消息
user_error() trigger_error() 的别名

PHP 预定义的错误和日志记录常量

常量 描述
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 代码中使用 PHP 函数 trigger_error() 生成的
512 E_USER_WARNING 非致命的用户生成警告。这类似于 E_WARNING,但它是在 PHP 代码中使用 PHP 函数 trigger_error() 生成的
1024 E_USER_NOTICE 用户生成通知。这类似于 E_NOTICE,但它是在 PHP 代码中使用 PHP 函数 trigger_error() 生成的
2048 E_STRICT 启用此选项可让 PHP 建议您的代码进行更改,以确保代码的最佳互操作性和前向兼容性(自 PHP 5 起,但直到 PHP 5.4 才包含在 E_ALL 中)
4096 E_RECOVERABLE_ERROR 可捕获的致命错误。表示发生了可能危险的错误,但并未使引擎处于不稳定状态。如果错误未被用户定义的处理程序捕获,应用程序将像 E_ERROR 一样中止(自 PHP 5.2 起)
8192 E_DEPRECATED 运行时通知。启用此项可接收有关未来版本中将无法工作的代码的警告(自 PHP 5.3 起)
16384 E_USER_DEPRECATED 用户生成的警告消息。这类似于 E_DEPRECATED,但它是在 PHP 代码中通过使用 PHP 函数 trigger_error() 生成的(自 PHP 5.3 起)
32767 E_ALL 启用所有 PHP 错误和警告(不包括 5.4 之前的版本中的 E_STRICT)

×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持