首页  >  文章  >  后端开发  >  为什么 mysqli_connect 失败时不出现我的自定义 PHP 错误消息?

为什么 mysqli_connect 失败时不出现我的自定义 PHP 错误消息?

Barbara Streisand
Barbara Streisand原创
2024-10-26 14:51:30133浏览

Why Doesn't My Custom PHP Error Message Appear When mysqli_connect Fails?

为什么 mysqli_connect 失败时 PHP 不显示我的自定义错误消息?

了解错误检测机制< ;/h3>

过去,PHP 的 mysql 扩展需要手动进行错误处理。不过,PHP 8.1 中引入的 mysqli 扩展现在会在遇到错误时自动触发异常,从而无需手动进行错误检测。

自定义错误消息混乱

您的代码包含一个 if (!$conn) 块,尝试输出自定义错误消息。这种方法已经过时了。 mysqli 本质上会抛出错误,这些错误应该自动处理。

隐藏用户的错误消息

要向站点访问者隐藏错误消息,您应该使用 display_errors 配置选项。将其设置为 0 将阻止 PHP 显示任何错误。您可以在 php.ini 中或使用 ini_set('display_errors', 0) 在 PHP 代码中设置此选项。

显示用户友好的错误页面

虽然向用户隐藏系统错误至关重要,但您可能希望显示用户友好的错误页面。这可以使用错误处理程序来实现,例如:

<code class="php">set_exception_handler(function ($e) {
    error_log($e);
    http_response_code(500);
    if (ini_get('display_errors')) {
        echo $e;
    } else {
        echo "<h1>500 Internal Server Error</h1>
              An internal server error has occurred.<br>
              Please try again later.";
    }
});</code>

此处理程序记录错误,设置 HTTP 500 状态代码,并在 display_errors 设置为 0 时显示通用错误消息。

处理连接错误

在某些情况下,您可能需要显式处理连接错误。这可以使用 try-catch 块来完成。但是,此类处理应仅限于特定错误场景需要替代操作的情况。

隐藏敏感信息

如果您担心敏感信息出现在堆栈跟踪,请考虑升级到 PHP 8.2 或更高版本,这会从堆栈跟踪中隐藏数据库密码。

以上是为什么 mysqli_connect 失败时不出现我的自定义 PHP 错误消息?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn