首頁 > 資料庫 > mysql教程 > 為什麼我的自訂 MySQLi 連線錯誤訊息沒有在 PHP 中顯示?

為什麼我的自訂 MySQLi 連線錯誤訊息沒有在 PHP 中顯示?

Barbara Streisand
發布: 2024-11-30 16:17:12
原創
749 人瀏覽過

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

PHP 中MySQLi 連線失敗的自訂錯誤訊息:綜合指南

在您的程式碼片段中,您遇到一個問題,其中自訂錯誤MySQLi 連線失敗時不顯示訊息。先前,PHP 的 mysql 擴充需要透過 if (!$conn) 檢查進行手動錯誤處理。然而,隨著 PHP 8.1 的出現,mysqli 現在會拋出錯誤異常,無需進行此類明確檢查。

為什麼不顯示自訂錯誤訊息

在現代 PHP 版本中,MySQLi 會自動連線失敗時會引發錯誤。因此,if (!$conn) 語句是不必要的,應將其刪除,以便有效處理異常。

修正程式碼

要解決此問題,您可以更新程式碼如下所示:

function connectDatabase(){
    $dbServerName = 'local_host';
    $dbUsername = 'root';
    $dbPassword = '';
    $dbName = 'kishor_me';

    try {
        $conn = mysqli_connect($dbServerName, $dbUsername, $dbPassword, $dbName);
    } catch (Exception $e) {
        // Handle the connection error here
    }
}
登入後複製

要向使用者隱藏錯誤

要隱藏錯誤訊息,您可以使用PHP display_errors設定選項:

ini_set('display_errors', 0);
登入後複製

顯示使用者友善的錯誤頁面

為了呈現更使用者友善的錯誤頁面,您可以實作錯誤處理程序:

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><br>An internal server error has been occurred.<br>Please try again later.';
    }
});
登入後複製

處理連線錯誤

當連線錯誤需要具體處理時,可以使用try..catch區塊:

try {
    $conn = mysqli_connect($dbServerName, $dbUsername, $dbPassword, $dbName);
} catch (Exception $e) {
    // Handle the connection error here
}
登入後複製

隱藏連線憑證

要防止資料庫密碼出現在錯誤訊息中,請升級到PHP 8.2 或更高版本。

以上是為什麼我的自訂 MySQLi 連線錯誤訊息沒有在 PHP 中顯示?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板