>  기사  >  백엔드 개발  >  PHP의 전역 오류 처리에 대한 자세한 설명

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

怪我咯
怪我咯원래의
2017-07-07 10:22:041423검색

php에는 프로덕션 환경에서 사용하기 어려운 자체 try{throw{}}catch{} 예외/오류 캡처 시스템이 있습니다. 일반적으로 예외/오류가 발생하면 PHP가 즉시 종료해야 합니다. 스크립트를 작성하여 방문자의 브라우저에 출력합니다. 오류 메시지를 표시하고 사용자 정의 기능

이 문서의 목적

PHP의 전역 오류 처리는 프로젝트를 개발할 때 매우 유용하며 개발자에게 도움이 될 수 있습니다. 일부 문제를 신속하게 찾아 작업 효율성을 향상시킵니다. 기본적으로 전역 오류는 직접 출력되지만, 최근 개발 중에 사용되는 프레임워크 라이브러리에서 전역 오류 처리를 설정했기 때문에 오류 메시지가 출력되지 않는 경우가 많아 문제를 찾는 데 시간이 많이 걸립니다. 그래서 이 라이브러리의 구현을 연구한 결과

error_reportingset_error_handler을 설정하여 이러한 현상이 발생한다는 사실을 발견했습니다. 이제 이 두 기능의 사용법을 메모로 기록해 보세요.

Background

PHP에는 유형 감지 기능이 없습니다. 개발자가 잘못된 단어를 입력하면 치명적인 오류가 발생하고 결국 스크립트 실행이 중단되기 쉽습니다. 이때 아무런 오류 메시지도 나오지 않는다면 매우 괴로운 일이 될 것입니다. 스크립트의 첫 번째 코드 줄부터 디버깅을 시작하고 철자가 틀린 단어를 찾을 때까지 수천 줄의 코드를 계속해서 인쇄하거나 에코해야 합니다. 그런 다음 이전에 추가한 인쇄물이나 에코를 모두 삭제해야 합니다. 이것은 매우 지루한 작업입니다.

일반적인 상황

일반적인 상황에서 PHP는 치명적인 오류를 직접 출력하고, 오류의 소스(파일 주소, 줄 번호)와 이유를 출력합니다. 이런 방식으로 개발자는 문제를 쉽게 찾을 수 있습니다.

그러나 때로는 php.ini 설정 문제나 타사 프레임워크 구성 문제로 인해 이 정보가 출력되지 않을 수 있습니다. 이 경우 문제를 빠르게 찾는 데 도움이 되도록 관련 매개변수를 직접 설정하고 이러한 오류 메시지를 출력하는 방법을 배워야 합니다. .

error_reporting

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를 제공합니다. 함수 프로토타입은 다음과 같습니다:

mixed set_error_handler ( callback $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 = &#39;Notice&#39;;
      break;
    case E_WARNING:
    case E_USER_WARNING:
      $error_type = &#39;Warning&#39;;
      break;
    case E_ERROR:
    case E_USER_ERROR:
      $error_type = &#39;Fatal Error&#39;;
      $EXIT = TRUE;
      break;
    default:
      $error_type = &#39;Unknown&#39;;
      $EXIT = TRUE;
      break;
  }
  printf ("%s: %s in %s on line %d\n", $error_type, $error_message, $file, $line);
 
  if ($EXIT) {
    die();
  }
}
set_error_handler (&#39;error_handler&#39;);
 
//new NonExist();
echo $novar;
echo 3/0;
trigger_error (&#39;Trigger a fatal error&#39;, E_USER_ERROR);
new NonExist();
?>

이 스크립트를 실행하여 다음 출력을 얻습니다.

Notice: Undefined variable: novar in /your/php_demo_file.php on line 40

Warning: pision 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는 최상위 예외 처리를 등록합니다. 웹 애플리케이션에서는 이를 설정한 후 균일하게 오류 처리 페이지로 이동할 수 있습니다.

위 내용은 PHP의 전역 오류 처리에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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