过去,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中文网其他相关文章!