>  기사  >  데이터 베이스  >  PHP 오류가 MySQL 데이터베이스에 직접 기록될 수 있습니까?

PHP 오류가 MySQL 데이터베이스에 직접 기록될 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-06 20:02:03698검색

Can PHP Errors be Directly Logged to a MySQL Database?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.