過去,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中文網其他相關文章!