理解问题:
在您的根据提供的代码,您尝试使用 mysqli_connect 连接到数据库,并在连接失败时打印自定义错误消息。但是,PHP 8.1 及更高版本以不同方式处理错误,引发异常而不需要手动处理。
隐藏的自定义错误消息:
从 PHP 8.1 开始,mysqli_connect 生成异常当发生错误时,这意味着您的代码不再需要手动检查连接状态。此外,您应该避免向用户显示自定义错误消息。相反,请使用 PHP 的错误处理机制或提供通用错误页面。
显示错误配置:
要防止 PHP 向用户显示错误消息,请设置 'display_errors ' php.ini 或代码中的选项为 0:
ini_set('display_errors', 0);
错误处理程序站点用户:
对于用户友好的错误页面,请使用记录错误、设置 HTTP 500 状态代码并显示一般错误消息或重定向到错误页面的错误处理程序。
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 been occurred.<br> Please try again later."; } });
单独处理连接错误:
如果要处理特别是连接错误,例如测试用户凭据,请在专用连接测试代码中使用 try..catch 块:
try { $conn = mysqli_connect(...); } catch (mysqli_sql_exception $e) { // Handle connection error }
隐藏连接凭据:
PHP 8.2以后从堆栈跟踪中隐藏数据库密码以提高安全性。
以上是为什么我的自定义 MySQLi 连接错误消息在 PHP 8.1 中不显示?的详细内容。更多信息请关注PHP中文网其他相关文章!