首頁 >後端開發 >php教程 >為什麼 mysqli_connect 失敗時不出現我的自訂 PHP 錯誤訊息?

為什麼 mysqli_connect 失敗時不出現我的自訂 PHP 錯誤訊息?

Barbara Streisand
Barbara Streisand原創
2024-10-26 14:51:30257瀏覽

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