




PHP错误报告级别必须写入配置文件才能持久生效,仅用error_reporting()或ini_set()仅影响当前脚本;推荐修改php.ini(需重启服务),也可用.htaccess(仅Apache且需AllowOverride开启);error_reporting与display_errors需配对设置,生产环境应关闭display_errors并开启log_errors,开发环境可开启display_errors;注意CLI与Web环境配置可能不同,须分别验证。
能,而且必须写进配置文件才能实现持久生效。仅靠 error_reporting() 函数或 ini_set('error_reporting', ...) 只影响当前脚本运行时,重启 PHP 或换脚本就失效。
关键是要区分两个配置位置:
php.ini(全局生效,推荐):修改后需重启 Web 服务器(如 Apache/Nginx + PHP-FPM).htaccess(仅 Apache,且 AllowOverride Op
tions 开启):无需重启,但不适用于 CLI 或 Nginx这两个选项要配对使用,否则可能“设了等于没设”。常见组合如下:
error_reporting = E_ALL & ~E_DEPRECATED & ~E_STRICTdisplay_errors = Offlog_errors = Onerror_log = /var/log/php_errors.log
error_reporting = E_ALLdisplay_errors = Onlog_errors = On
注意:display_errors = On 在 CGI/FastCGI 模式下(如多数 Nginx 配置)可能被忽略,此时必须依赖浏览器端是否收到 PHP Notice 响应头——实际仍取决于 SAPI 层行为,不能完全信任。
立即学习“PHP免费学习笔记(深入)”;
常见原因不是配置写错,而是没找对生效的配置文件,或未触发重载:
php --ini 查 CLI 使用的 php.ini;用 phpinfo() 页面查 Web SAPI 加载的实际路径php.ini 通常在 /etc/php/{version}/fpm/php.ini,改完要执行 sudo systemctl reload php{version}-fpm
conf.d/ 目录下的扩展配置),后面加载的会覆盖前面的同名指令display_errors 被 .user.ini 或 ini_set() 运行时覆盖,可用 var_dump(ini_get('display_errors')); 确认最终值PHP 允许为 CLI 和 Web SAPI 分别指定配置文件(通过 --php-ini 或编译时设定),所以 php -v 显示的 error_reporting 值,和 phpinfo() 里看到的可能完全不同。
验证方式必须分开:
php -r "var_dump(error_reporting());"
test.php,内容为 ,通过浏览器访问很多线上问题就出在这里——开发者只调通了 CLI 脚本,却没检查 Web 请求是否真关掉了错误显示。