>백엔드 개발 >PHP 튜토리얼 >PHP의 전역 오류 처리_php 기술에 대한 자세한 설명

PHP의 전역 오류 처리_php 기술에 대한 자세한 설명

WBOY
WBOY원래의
2016-05-16 19:53:501305검색

이 글의 목적

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

기본적으로 PHP는 알림을 제외한 모든 오류 메시지를 출력합니다. 마찬가지로, PHP 표준 함수는 PHP 스크립트에서 동일한 함수를 완성하는 데 사용되는 동일한 이름의 error_reporting(int $level) 함수를 제공합니다. 이는 다른 프로그램에 영향을 미치지 않습니다. $level이 0이면 오류 출력이 꺼진다는 점, 즉 오류가 출력되지 않는다는 점에 유의할 가치가 있습니다.

set_error_handler

PHP의 기본 오류 처리는 메시지를 출력하는 것입니다. 그러나 때로는 다른 작업을 정의해야 하는 경우도 있으며, 이 경우 오류 처리 기능을 사용자 정의해야 합니다. PHP는 자체 오류 처리 함수를 등록하는 데 도움이 되는 내장 함수 set_error_handler를 제공합니다. 함수 프로토타입은 다음과 같습니다.

혼합 set_error_handler( 콜백 $error_handler [, int $error_types = E_ALL | E_STRICT ] )

오류 처리 기능을 등록하더라도 기본 동작은 계속 실행된다는 점, 즉 오류가 발생하면 오류 메시지가 계속 출력되므로 오류 수준을 로 설정해야 한다는 점에 유의할 필요가 있습니다. 0을 프로그램에 넣은 다음 자신만의 오류 처리 기능을 등록하세요. 이 접근 방식은 프로덕션 환경에서 특히 중요합니다. 문제가 발생하더라도 민감한 내부 오류 정보가 잠재적으로 악의적인 사용자에게 노출되지 않기 때문입니다. 사용자 정의 오류 처리 함수는 치명적인 오류(예: 컴파일 오류)를 처리할 수 없다는 점을 지적하는 것도 중요합니다. 다음은 사용자 정의 오류 처리 기능을 사용하는 예입니다.

<&#63;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();
&#63;>
이 스크립트를 실행하면 다음과 같은 결과가 출력됩니다.

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

보시다시피 최종 "new NoExistClass()" 예외는 사용자 정의 오류 처리 기능에 의해 포착되지 않았습니다.

마지막으로 set_Exception_handler는 웹 애플리케이션에서 최상위 예외 처리를 등록한 후 균일하게 오류 처리 페이지로 이동할 수 있습니다.

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