이 글의 목적
PHP의 전역 오류 처리는 프로젝트 개발 시 매우 유용하며 개발자가 신속하게 문제를 찾아 작업 효율성을 향상시키는 데 도움이 됩니다. 기본적으로 전역 오류는 직접 출력되지만, 최근 개발 중에 사용되는 프레임워크 라이브러리에서 전역 오류 처리를 설정했기 때문에 오류 메시지가 출력되지 않는 경우가 많아 문제를 찾는 데 시간이 많이 걸립니다. 그래서 이 라이브러리의 구현을 연구한 결과 error_reporting과 set_error_handler를 설정하여 이러한 현상이 발생하는 것을 발견했습니다. 이제 이 두 기능의 사용법을 메모로 기록해 보세요.
배경
PHP에는 유형 감지 기능이 없습니다. 개발자가 잘못된 단어를 입력하면 치명적인 오류가 발생하고 결국 스크립트 실행이 중단되기 쉽습니다. 이때 아무런 오류 메시지도 나오지 않는다면 매우 괴로운 일이 될 것입니다. 스크립트의 첫 번째 코드 줄부터 디버깅을 시작하고 철자가 틀린 단어를 찾을 때까지 수천 줄의 코드를 계속해서 인쇄하거나 에코해야 합니다. 그런 다음 이전에 추가한 인쇄물이나 에코를 모두 삭제해야 합니다. 이것은 매우 지루한 작업입니다.
일반 조건
일반적인 상황에서 PHP는 치명적인 오류를 직접 출력하고 오류 소스(파일 주소, 줄 번호) 및 이유 등을 출력합니다. 이러한 방식으로 개발자는 문제를 쉽게 찾을 수 있습니다.
그러나 때때로 php.ini 설정이나 타사 프레임워크 구성 문제로 인해 이 정보가 출력되지 않을 수 있습니다. 이때 관련 매개변수를 직접 설정하고 이러한 오류 메시지를 출력하는 방법을 배워야 질문을 빠르게 찾을 수 있습니다.
오류 보고
error_reporting은 php.ini의 PHP 전역 구성 매개변수입니다. 오류 출력 수준을 구성하는 데 사용됩니다. 매개변수는 오류 출력 수준을 설정하는 데 사용할 수 있습니다. 다음은 php.ini에서 복사한 정보입니다.
; error_reporting is a bit-field. Or each number up to get desired error ; reporting level ; E_ALL - All errors and warnings (doesn't include E_STRICT) ; E_ERROR - fatal run-time errors ; E_RECOVERABLE_ERROR - almost fatal run-time errors ; E_WARNING - run-time warnings (non-fatal errors) ; E_PARSE - compile-time parse errors ; E_NOTICE - run-time notices (these are warnings which often result ; from a bug in your code, but it's possible that it was ; intentional (e.g., using an uninitialized variable and ; relying on the fact it's automatically initialized to an ; empty string) ; E_STRICT - run-time notices, enable to have PHP suggest changes ; to your code which will ensure the best interoperability ; and forward compatibility of your code ; E_CORE_ERROR - fatal errors that occur during PHP's initial startup ; E_CORE_WARNING - warnings (non-fatal errors) that occur during PHP's ; initial startup ; E_COMPILE_ERROR - fatal compile-time errors ; E_COMPILE_WARNING - compile-time warnings (non-fatal errors) ; E_USER_ERROR - user-generated error message ; E_USER_WARNING - user-generated warning message ; E_USER_NOTICE - user-generated notice message ; ; Examples: ; ; - Show all errors, except for notices and coding standards warnings ; ;error_reporting = E_ALL & ~E_NOTICE ; ; - Show all errors, except for notices ; ;error_reporting = E_ALL & ~E_NOTICE | E_STRICT ; ; - Show only errors ; ;error_reporting = E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR ; ; - Show all errors except for notices and coding standards warnings ; error_reporting = E_ALL & ~E_NOTICE
set_error_handler
PHP의 기본 오류 처리는 메시지를 출력하는 것입니다. 그러나 때로는 다른 작업을 정의해야 하는 경우도 있으며, 이 경우 오류 처리 기능을 사용자 정의해야 합니다. PHP는 자체 오류 처리 함수를 등록하는 데 도움이 되는 내장 함수 set_error_handler를 제공합니다. 함수 프로토타입은 다음과 같습니다.혼합 set_error_handler( 콜백 $error_handler [, int $error_types = E_ALL | E_STRICT ] )
오류 처리 기능을 등록하더라도 기본 동작은 계속 실행된다는 점, 즉 오류가 발생하면 오류 메시지가 계속 출력되므로 오류 수준을 로 설정해야 한다는 점에 유의할 필요가 있습니다. 0을 프로그램에 넣은 다음 자신만의 오류 처리 기능을 등록하세요. 이 접근 방식은 프로덕션 환경에서 특히 중요합니다. 문제가 발생하더라도 민감한 내부 오류 정보가 잠재적으로 악의적인 사용자에게 노출되지 않기 때문입니다. 사용자 정의 오류 처리 함수는 치명적인 오류(예: 컴파일 오류)를 처리할 수 없다는 점을 지적하는 것도 중요합니다. 다음은 사용자 정의 오류 처리 기능을 사용하는 예입니다.
<?php error_reporting (0); function error_handler ($error_level, $error_message, $file, $line) { $EXIT = FALSE; switch ($error_level) { case E_NOTICE: case E_USER_NOTICE: $error_type = 'Notice'; break; case E_WARNING: case E_USER_WARNING: $error_type = 'Warning'; break; case E_ERROR: case E_USER_ERROR: $error_type = 'Fatal Error'; $EXIT = TRUE; break; default: $error_type = 'Unknown'; $EXIT = TRUE; break; } printf ("%s: %s in %s on line %d\n", $error_type, $error_message, $file, $line); if ($EXIT) { die(); } } set_error_handler ('error_handler'); //new NonExist(); echo $novar; echo 3/0; trigger_error ('Trigger a fatal error', E_USER_ERROR); new NonExist(); ?>
Notice: Undefined variable: novar in /your/php_demo_file.php on line 40 Warning: Division by zero in /your/php_demo_file.php on line 41 Fatal Error: Trigger a fatal error in /your/php_demo_file.php on line 42
마지막으로 set_Exception_handler는 웹 애플리케이션에서 최상위 예외 처리를 등록한 후 균일하게 오류 처리 페이지로 이동할 수 있습니다.