error_reporting()需配合display_errors和log_errors才真正生效;它仅控制错误级别,不决定输出位置,且无法捕获Parse/Fatal error,后者须靠php.ini配置或register_shutdown_function兜底。

php如何设置错误报告级别_php设置错误报告级别方法【配置】

error_reporting() 函数怎么设才真正生效

直接用 error_reporting(E_ALL) 不一定能看到所有错误——它只控制 PHP 运行时的错误报告开关,不碰 display_errorslog_errors。常见现象是:代码里写了 error_reporting(E_ALL),但 parse error(比如少个括号)还是不显示,因为语法解析阶段根本没走到这行。

php.ini 里设置 error_reporting 的坑在哪

php.ini 中的 error_reporting 值必须是整数或常量名字符串(如 E_ALL & ~E_NOTICE),但实际填进去的几乎全是整数——因为 ini 文件不支持表达式计算。你写 error_reporting = E_ALL & ~E_DEPRECATED,PHP 会当成字符串处理,最终等效于 0(即关闭所有错误报告)。

开发环境 vs 生产环境该设什么级别

开发时追求“宁可错报,不可漏报”,生产则相反:要静默失败,防止信息泄露。但很多人把 error_reporting(0) 当成万能开关,结果连 Fatal error 都不记录,服务挂了都不知道。

为什么 set_error_handler() 拦不住 Fatal error

set_error_handler() 只捕获 E_ERROR 以下级别的错误(如 E_WARNINGE_NOTICE),对 Fatal errorParse errorTypeError(某些情况)完全无效。这是 PHP 的底层限制,不是配置问题。

真正难的不是设哪个数字,而是理解 error_reporting 控制的是“哪些错误发出来”,而 display_errors/log_errors 决定“发到哪去”——三者缺一不可,且作用阶段不同。漏掉任意一层,都会让你以为“设置了却没用”。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。