>  기사  >  데이터 베이스  >  error_log 파일 대신 PHP 오류를 MySQL 데이터베이스에 기록하려면 어떻게 해야 합니까?

error_log 파일 대신 PHP 오류를 MySQL 데이터베이스에 기록하려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-11-06 06:35:02911검색

How can I log PHP errors to a MySQL database instead of the error_log file?

Error_Log를 수정하지 않고 데이터베이스에 PHP 오류 출력

기본적으로 PHP 오류는 표준 error_log 파일에 기록됩니다. 대신 이러한 오류를 MySQL 데이터베이스로 보내려면 사용자 정의 오류 핸들러를 사용하는 것이 좋습니다.

이 솔루션을 구현하려면 오류 세부 정보를 처리하고 데이터베이스에 기록하는 사용자 정의 오류 핸들러 함수를 생성하세요. 예를 들면 다음과 같습니다.

function myErrorHandler($errno, $errstr, $errfile, $errline)
{
    // Establish a database connection or utilize an existing one
    
    // Prepare and execute an SQL query to insert the error details
    mysql_query("INSERT INTO error_log (number, string, file, line) ".
                 "VALUES .....");         
    
    // Prevent execution of the default PHP error handler
    return true;
}

다음에 사용자 정의 오류 처리기를 전역 오류 처리기로 설정할 수 있습니다.

// Disable the default error handler
$old_error_handler = set_error_handler("myErrorHandler");

이 사용자 정의 오류 처리기를 사용하면 모든 PHP 오류 error_log 파일 대신 지정된 MySQL 데이터베이스로 이동됩니다.

위 내용은 error_log 파일 대신 PHP 오류를 MySQL 데이터베이스에 기록하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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