以前は、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 中国語 Web サイトの他の関連記事を参照してください。