PHP 오류를 데이터베이스에 직접 기록
표준 error_log 파일에 의존하는 대신 모든 오류를 다음으로 출력하도록 PHP를 구성할 수 있습니까? MySQL 데이터베이스?
솔루션
사용자 정의 오류 핸들러를 작성하지 않고 이를 달성할 수 있는 직접적인 방법은 없지만 단일 전역 변경 사항을 적용할 수 있습니다. 사용자 정의 오류 핸들러를 생성하는 것은 오류 메시지를 데이터베이스로 리디렉션하는 데 핵심입니다.
코드 예
아래는 PHP 매뉴얼에서 수정된 예입니다.
function myErrorHandler($errno, $errstr, $errfile, $errline) { $connection = ...; // Establish connection with MySQL $query = "INSERT INTO error_log (number, string, file, line) ". "VALUES ($errno, $errstr, $errfile, $errline)"; $result = mysql_query($query, $connection); return true; // Suppress PHP's internal error handling }
사용자 정의 오류 핸들러를 설정하려면:
$old_error_handler = set_error_handler("myErrorHandler");
이 사용자 정의 오류 핸들러를 구현하면 모든 PHP 오류가 지정된 MySQL 데이터베이스에 자동으로 기록되어 중앙 집중화되고 보다 체계화된 데이터베이스를 제공합니다. 오류를 관리하는 방법.
위 내용은 PHP 오류가 MySQL 데이터베이스에 직접 기록될 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!