8

正如许多其他问题所指出的,在 php.ini 中将 display_errors 设置为 Off 会使 Web 服务器在遇到致命错误时以状态码 500 Internal server error 而不是 200 OK 回答。我用一个未定义的函数设置了一个简单的测试来解释这种行为:

php.ini

display_errors = On

索引.php

<?php test();

给出:

Fatal error: Call to undefined function test()
in D:\xampp\htdocs\index.php on line 1

或者如果我像这样使函数调用静音,则只是一个空白页:

<?php @test();

在这两种情况下,答案标题如下:

HTTP/1.1 200 OK
Date: Tue, 10 Jul 2012 20:08:22 GMT
Server: Apache/2.2.21 (Win32) mod_ssl/2.2.21 OpenSSL/1.0.0e PHP/5.3.8 mod_perl/2.0.4 Perl/v5.10.1
X-Powered-By: PHP/5.3.8
Content-Length: 0
Keep-Alive: timeout=5, max=100
Connection: Keep-Alive
Content-Type: text/html

将 php.ini 更改为:

display_errors = Off

原因:

HTTP/1.0 500 Internal Server Error
Date: Tue, 10 Jul 2012 20:10:35 GMT
Server: Apache/2.2.21 (Win32) mod_ssl/2.2.21 OpenSSL/1.0.0e PHP/5.3.8 mod_perl/2.0.4 Perl/v5.10.1
X-Powered-By: PHP/5.3.8
Content-Length: 0
Connection: close
Content-Type: text/html

任何人都可以向我解释当 display_errors 关闭时使 Web 服务器回答 500 的底层机制吗?

4

1 回答 1

8

原因是,使用display_errors = On,您实际上是在要求 PHP 给您一个不错的 HTTP 响应,即使您的脚本中有错误也是如此。将其视为脚本和响应之间的附加层。它不再是您的脚本控制输出,而是 PHP。

当您打开此选项时,您实际上是在说,“如果有错误,请仍然给我一个有效的 HTTP 响应页面(它甚至可能包含适当的标记),因为我将查看而不是我的日志。 "

设置为Off时,HTTP 响应应该是无意义的,因此是 500。使用它时,预计会出现 PHP 错误,因此即使您的脚本失败,整个请求也不是 500。

于 2012-07-10T20:22:00.773 回答