데이터베이스 연결을 설정하려고 할 때 정의한 사용자 정의 오류 메시지가 표시되지 않는 문제가 발생했습니다. 연결이 실패했을 때 표시됩니다. 또한 사용자 보기에서 오류 메시지를 억제하는 방법을 찾고 있습니다.
PHP 8.1부터 mysqli 확장은 이제 오류 발생 시 자동으로 예외를 발생시킵니다. 오류가 발생하면 이전 버전의 PHP에서 수행되었던 수동 오류 처리가 필요하지 않습니다.
정의한 것과 같은 사용자 정의 오류 메시지는 더 이상 권장되지 않습니다. 오류 처리. PDO와 mysqli 모두 다른 PHP 명령과 마찬가지로 오류를 자동으로 발생시키는 기능이 있습니다. 따라서 if(!$conn) 세그먼트를 사용하여 시도했던 것처럼 수동으로 오류를 확인하는 것은 더 이상 사용되지 않습니다.
오류 메시지가 사용자에게 전달되지 않도록 하려면 , 모든 오류 출력을 억제하려면 0으로 설정할 수 있는 display_errors 구성 옵션을 활용해야 합니다. 이는 php.ini 파일이나 PHP 코드에서 직접 구성할 수 있습니다.
<code class="php">ini_set('display_errors', 0);</code>
암호적인 오류 메시지를 표시하는 대신 다음을 수행하는 것이 좋습니다. 사이트 방문자에게 사용자 친화적인 오류 페이지를 제공합니다. 이는 복구할 수 없는 모든 오류를 포착하는 아래와 같은 오류 처리기를 설정하여 달성할 수 있습니다.
<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>\nAn internal server error has been occurred.<br>\nPlease try again later."; } });</code>
특별히 처리해야 하는 경우 데이터베이스 연결 오류가 발생하면 일반 연결 코드와 별도로 try-catch 블록에 래핑된 별도의 연결 테스트 스크립트를 사용할 수 있습니다.
보안 강화를 위해 PHP 버전을 업데이트하세요. 8.2 이상으로 변경하면 스택 추적에 데이터베이스 비밀번호가 표시되지 않습니다.
위 내용은 PHP 8.1로 업그레이드한 후 mysqli_connect 실패 시 내 사용자 정의 오류 메시지가 표시되지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!