为什么我的自定义 MySQLi 连接错误消息在 PHP 8.1 中不显示?

Susan Sarandon
发布: 2024-11-26 11:56:10
原创
101 人浏览过

Why Aren't My Custom MySQLi Connection Error Messages Displaying in PHP 8.1 ?

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

理解问题:

在您的根据提供的代码,您尝试使用 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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板