>  기사  >  백엔드 개발  >  error_reporting 사용법 알아보기

error_reporting 사용법 알아보기

WBOY
WBOY원래의
2016-07-25 09:11:481119검색

PHP 프로그래밍에서 error_reporting의 빈도를 모두가 잘 알고 있어야 합니다. 이 기사에서는 참고용으로 error_reporting의 사용법을 소개합니다. 매개변수 수준을 지정하지 않으면 현재 오류 수준이 반환됩니다. 레벨에 가능한 값은 다음과 같습니다. 1E_ERROR 2 E_경고 4E_PARSE 8 E_공지사항 16 E_CORE_ERROR 32 E_CORE_경고 64 E_COMPILE_ERROR 128 E_컴파일_경고 256 E_USER_ERROR 512 E_USER_경고 1024 E_USER_NOTICE 2047 E_ALL 2048 E_STRICT E_NOTICE는 정상적인 상황은 기록되지 않는다는 뜻으로, 존재하지 않는 변수에 접근을 시도하거나, 존재하지 않는 파일을 보기 위해 stat() 함수를 호출하는 등 프로그램에 오류가 발생한 경우에만 사용된다. E_WARNING은 일반적으로 표시되지만 프로그램 실행을 중단하지는 않습니다. 이는 디버깅에 유용합니다. 예: 문제가 있는 정규 표기법으로 ereg()를 호출합니다. E_ERROR는 일반적으로 표시되며 프로그램 실행을 중단합니다. 즉, 이 마스크를 사용하면 메모리 구성이나 기타 오류를 추적할 수 없습니다. E_PARSE 구문에서 오류를 구문 분석합니다. E_CORE_ERROR E_ERROR와 비슷하지만 PHP 코어로 인해 발생한 오류는 제외됩니다. E_CORE_WARNING E_WARNING과 비슷하지만 PHP 핵심 오류 경고를 포함하지 않습니다.

PHP 오류 보고서

php.ini 파일에는 많은 구성 설정이 있습니다. Linux에 PHP 및 Apache 2 설치에 대한 설명서에 표시된 대로 php.ini 파일을 이미 설정하여 적절한 디렉터리에 배치했어야 합니다. PHP 애플리케이션을 디버깅할 때 알아야 할 두 가지 구성 변수가 있습니다. 두 가지 변수와 해당 기본값은 다음과 같습니다. display_errors = 끄기 error_reporting = E_ALL

이 두 변수의 현재 기본값은 php.ini 파일에서 검색하여 확인할 수 있습니다. display_errors 변수의 목적은 분명합니다. 이는 PHP에 오류를 표시할지 여부를 알려줍니다. 기본값은 끄기입니다. 그러나 개발 프로세스를 더 쉽게 만들려면 이 값을 On으로 설정하십시오. display_errors = 켜짐

error_reporting 변수의 기본값은 E_ALL입니다. 이 설정은 잘못된 코딩 관행부터 무해한 팁, 오류까지 모든 것을 보여줍니다. E_ALL은 브라우저의 출력을 엉망으로 만드는 작은 일(예: 변수가 초기화되지 않음)에 대한 힌트도 화면에 표시하므로 개발 목적에 비해 너무 세분화되어 있습니다. 오류와 잘못된 코딩 관행만 보고 싶고 무해한 팁은 보고 싶지 않습니다. 따라서 error_reporting의 기본값을 다음 값으로 바꾸십시오. error_reporting = E_ALL & ~E_NOTICE

Apache를 다시 시작하면 모든 준비가 완료됩니다. 다음으로 Apache에서 동일한 작업을 수행하는 방법을 알아봅니다.

서버의 오류 보고는 Apache가 수행하는 작업에 따라 달라지며, 시스템에 여러 버전의 PHP가 있을 수 있으므로 PHP에서 오류 보고를 켜는 것이 작동하지 않을 수 있습니다. Apache는 하나의 php.ini 파일만 볼 수 있기 때문에 Apache가 어떤 PHP 버전을 사용하고 있는지 알기 어려울 때가 있습니다. Apache가 자체 구성을 위해 어떤 php.ini 파일을 사용하는지 모르는 것은 보안 문제입니다. 그러나 올바른 오류 수준이 설정되도록 Apache에서 PHP 변수를 구성하는 방법이 있습니다.

또한 서버 측에서 이러한 구성 변수를 설정하여 php.ini 파일을 재정의하거나 선점하여 더 높은 수준의 보안을 제공하는 방법을 아는 것도 좋습니다.

Apache를 구성할 때 /conf/httpd.conf의 http.conf 파일에서 기본 구성을 이미 터치했어야 합니다.

php.ini 파일에서 이미 수행한 작업을 수행하려면 httpd.conf에 다음 줄을 추가하여 모든 php.ini 파일을 덮어씁니다. php_flag 디스플레이_오류 켜짐 php_value 오류_보고 2039 이는 php.ini 파일에 이미 display_errors에 대해 설정된 플래그와 error_reporting 값을 재정의합니다. 값 2039는 E_ALL & ~E_NOTICE를 나타냅니다. E_ALL을 사용하려면 값을 2047로 설정하세요. 이번에도 Apache를 다시 시작해야 합니다.

다음으로 서버에서 오류 보고를 테스트합니다.

error_reporting() 함수와 관련하여 일부 오류 메시지를 보호할 수 있지만 PHP 코어로 인해 발생한 오류는 보호할 수 없습니다. 왜냐하면 PHP 코어로 인해 발생한 오류는 직접적으로 PHP 파일 컴파일 실패를 초래하기 때문입니다. PHP 코딩 규칙 작성으로 인해 발생하는 오류는 차단할 수 없습니다.

  1. * 지금은 E_STRICT 모드 경고를 피하세요
  2. * (함수 정의 전에 수행해야 함)
  3. */
  4. if ( 정의됨('E_STRICT')) {
  5. $old_error_reporting = error_reporting(0);
  6. if ($old_error_reporting & E_STRICT) {
  7. error_reporting($old_error_reporting ^ E_STRICT);
  8. } else {
  9. error_reporting($old_error_reporting);
  10. }
  11. unset($old_error_reporting);
코드 복사

공통적인 것은 다음과 같습니다.

  1. // 모든 오류 보고 끄기, 모든 오류 끄기
  2. error_reporting(0);
  3. // 단순 실행 오류 보고 ;간단한 실행 오류 보고
  4. error_reporting(E_ERROR | E_WARNING | E_PARSE);
  5. // E_NOTICE 보고도 유용할 수 있습니다(초기화되지 않은 변수를 보고하거나
  6. // 변수를 보고하거나 변수 이름 철자가 틀린 것을 잡기 위해…) ; 초기화되지 않은 일부 변수 보고 포함 또는 변수 이름 오타 잡기
  7. error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
  8. // E_NOTICE를 제외한 모든 오류 보고
  9. // php.ini; E_NOTICE를 제외한 모든 오류 보고
  10. error_reporting(E_ALL ^ ​​​​E_NOTICE);
  11. // 모든 PHP 오류 보고(PHP 3에서는 비트 단위 63이 사용될 수 있음); >error_reporting(E_ALL);
  12. // error_reporting(E_ALL)과 동일; 위와 동일
  13. ini_set('error_reporting', E_ALL);
코드 복사

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