PHP에서는 기본 오류 처리가 간단합니다. 파일 이름, 줄 번호 및 오류를 설명하는 메시지와 함께 오류 메시지가 브라우저로 전송됩니다.
PHP 오류 처리
오류 처리는 스크립트와 웹 애플리케이션을 만들 때 중요한 부분입니다. 코드에 오류 감지 코딩이 없으면 프로그램이 비전문적으로 보이고 보안 위험이 발생할 수 있습니다.
이 튜토리얼에서는 PHP에서 가장 중요한 오류 감지 방법 중 일부를 다룹니다.
다양한 오류 처리 방법을 설명합니다:
1. 간단한 "die()" 문
2. 사용자 정의 오류 및 오류 트리거
3. 오류 보고
기본 오류 처리: die() 함수 사용
첫 번째 예는 텍스트 파일에 대한 개방형 단순 스크립트를 보여줍니다. :
<?php $file=fopen("welcome.txt","r"); ?>
파일이 없으면 다음과 같은 오류가 발생합니다.
경고: fopen(welcome.txt) [function.fopen]: failed to open stream :
2행의 /www/php/test/test.php에 해당 파일이나 디렉토리가 없습니다.
사용자가 위와 같은 오류 메시지를 받지 않도록 하려면 다음을 확인합니다. 액세스하기 전에 파일이 존재하는 경우:
<?php if(!file_exists("welcome.txt")) { die("文件不存在"); } else { $file=fopen("welcome.txt","r"); } ?>
이제 파일이 존재하지 않으면 다음과 같은 오류 메시지가 표시됩니다.
파일이 존재하지 않습니다
위 코드는 오류 발생 후 스크립트를 종료하기 위해 간단한 오류 처리 메커니즘을 사용하기 때문에 이전 코드보다 더 효율적입니다.
그러나 단순히 스크립트를 종료하는 것이 항상 적절한 것은 아닙니다. 오류 처리를 위한 대체 PHP 함수를 살펴보겠습니다.
사용자 정의 오류 핸들러 생성
사용자 정의 오류 핸들러를 생성하는 것은 매우 쉽습니다. PHP에서 오류가 발생할 때 호출할 수 있는 전용 함수를 만들었습니다.
함수는 최소 2개의 매개변수(오류 수준 및 오류 메시지)를 처리할 수 있어야 하지만 최대 5개의 매개변수(선택 사항: 파일, 줄 번호 및 오류 컨텍스트)를 허용할 수 있습니다.
구문
error_function(error_level, error_message, error_file, error_line, error_context)
매개변수 🎜> error_level 필수입니다. 사용자 정의 오류에 대한 오류 보고 수준을 지정합니다. 숫자여야 합니다. 아래 표를 참조하세요. 오류 보고 수준.
error_message 필수입니다. 사용자 정의 오류에 대한 오류 메시지를 지정합니다.
error_file 선택사항. 오류가 발생한 파일 이름을 지정합니다.
error_line 선택사항. 오류가 발생한 줄 번호를 지정합니다.
error_context 선택사항. 오류가 발생했을 때 사용된 각 변수와 해당 값을 포함하는 배열을 지정합니다.
오류 보고 수준
이 오류 보고 수준은 사용자 정의 오류 처리기가 처리하는 다양한 유형의 오류입니다.
값 E_WARNING 치명적이지 않은 런타임 오류입니다. 스크립트 실행을 일시 중지하지 마십시오. 8 E_NOTICE 런타임 알림. 스크립트가 가능한 오류를 발견할 때 발생하지만 스크립트가 정상적으로 실행될 때도 발생할 수 있습니다.
256 E_USER_ERROR 치명적인 사용자 생성 오류입니다. 이는 프로그래머가 PHP 함수 Trigger_error()를 사용하여 설정한 E_ERROR와 유사합니다.512 E_USER_WARNING 치명적이지 않은 사용자 생성 경고입니다. 이는 프로그래머가 PHP 함수 Trigger_error()를 사용하여 설정한 E_WARNING과 유사합니다.
1024 E_USER_NOTICE 사용자 생성 알림. 이는 프로그래머가 PHP 함수 Trigger_error()를 사용하여 설정한 E_NOTICE와 유사합니다.
4096 E_RECOVERABLE_ERROR 추적 가능한 치명적인 오류입니다. E_ERROR와 비슷하지만 사용자 정의 핸들러로 포착할 수 있습니다. (set_error_handler() 참조)
8191 E_ALL 모든 오류 및 경고. (PHP 5.4에서는 E_STRICT가 E_ALL의 일부가 됩니다.)
위 유형에서:
1. 오류가 가장 심각하므로 해결해야 합니다. 그렇지 않으면 프로그램을 계속 실행할 수 없습니다.
2. 경고도 매우 중요합니다. 통(Tong)도 해결해야 한다. 명확하고 의도적이라면 처리할 필요가 없습니다
3. 공지사항 처리하지 않아도 됩니다. 그러나 일부 회사에서는 프로젝트 표준이 특히 높습니다. 이는 또한 높은 표준 요구 사항을 가진 프로젝트에서도 해결되어야 합니다. 통지는 PHP의 실행 효율성에 영향을 미치기 때문입니다. 주로 함수가 정의되지 않은 경우 등에 발생합니다.
4. 구문 분석 오류는 구문 오류 및 오타를 의미하며 이를 해결해야 합니다
5. all은 모든 유형의 오류를 나타냅니다
이제 오류를 처리하는 함수를 만들어 보겠습니다.
function customError($errno, $errstr)
{
echo "<b>오류:</b> [$errno] $errstr<br>";
echo "End of script";
die();
} }
위 코드는 간단한 오류 처리 함수입니다. 트리거되면 오류 수준과 오류 메시지가 표시됩니다. 그런 다음 오류 수준과 메시지를 인쇄하고 스크립트를 종료합니다.
이제 오류 처리 기능을 만들었으므로 언제 실행할지 결정해야 합니다.
오류 핸들러 설정
PHP의 기본 오류 핸들러는 내장된 오류 핸들러입니다. 스크립트가 실행될 때 위 함수를 기본 오류 처리기로 변환하겠습니다.
오류 핸들러를 수정하여 특정 오류에만 적용하면 스크립트가 다양한 오류를 다양한 방식으로 처리할 수 있습니다. 그러나 이 경우 모든 오류에 대해 사용자 정의 오류 처리기를 사용할 것입니다.
set_error_handler("customError");
우리가 원하기 때문에 사용자 정의 함수는 모든 오류를 처리하려면 set_error_handler()에는 하나의 매개변수만 필요하며 오류 수준을 지정하기 위해 두 번째 매개변수를 추가할 수 있습니다.
예
존재하지 않는 변수를 출력하여 이 오류 핸들러를 테스트합니다.
<?php // 错误处理函数 function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr"; } // 设置错误处理函数 set_error_handler("customError"); // 触发错误 echo($test); ?>
위 코드의 출력은 다음과 같습니다.
오류: [8] 정의되지 않은 변수: test
가 오류를 유발합니다
in 사용자가 데이터를 입력하는 스크립트의 위치로, 사용자 입력이 유효하지 않을 때 오류를 트리거하는 데 유용합니다. PHP에서 이 작업은 Trigger_error() 함수에 의해 수행됩니다.
예
이 예에서 "test" 변수가 "1"보다 크면 오류가 발생합니다.
<?php $test=2; if ($test>1) { trigger_error("变量值必须小于等于 1"); } ?>
위 코드의 출력은 다음과 같습니다. 예:
참고: 변수 값은 5행의 /www/test/php.php
<🎜에서 1
보다 작거나 같아야 합니다. >
이 예에서는 "test" 변수가 "1"보다 크면 E_USER_WARNING 오류가 발생합니다. E_USER_WARNING이 발생하면 사용자 정의 오류 처리기를 사용하고 스크립트를 종료합니다.
<?php // 错误处理函数 function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr<br>"; echo "脚本结束"; die(); } // 设置错误处理函数 set_error_handler("customError",E_USER_WARNING); // 触发错误 $test=2; if ($test>1) { trigger_error("变量值必须小于等于 1",E_USER_WARNING); } ?>
위 코드의 출력은 다음과 같습니다.
오류: [512] 변수 값 1보다 작거나 같아야 합니다.
스크립트 종료
자체 오류를 생성하는 방법과 오류를 유발하는 방법을 배웠으니 이제 오류 레코드를 연구해 보겠습니다.
오류 기록
php.ini에서 사용해야 하는 관련 구성 항목은 다음과 같습니다. 이 두 구성 항목은 다음과 같습니다.
매개변수 🎜>log_errors 켜기/끄기 > > 오류 로그가 기록되는 경로를 지정하세요. 설명: log_errors 및 log_errors_max_len 테이블은 이해하기 매우 쉽습니다.
그리고 error_log는 오류가 저장될 경로를 지정합니다. 구성 항목의 syslog는 다소 이해하기 어려울 수 있습니다. syslog는 시스템 기록을 나타냅니다. Windows 시스템은 컴퓨터의 로그 수집기에 있습니다. Linux 기본값은 다음과 같습니다. /etc/syslog.conf
기본적으로 php.ini의 error_log 구성에 따라 PHP는 오류 기록을 서버의 기록 시스템이나 파일로 보냅니다. error_log() 함수를 사용하면 오류 기록을 지정된 파일이나 원격 대상으로 보낼 수 있습니다. 자신에게 오류 메시지를 이메일로 보내는 것은 특정 오류에 대한 알림을 받을 수 있는 좋은 방법입니다.
<?php // 错误处理函数 function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr<br>"; echo "已通知网站管理员"; error_log("Error: [$errno] $errstr",1, "someone@example.com","From: webmaster@example.com"); } // 设置错误处理函数 set_error_handler("customError",E_USER_WARNING); // 触发错误 $test=2; if ($test>1) { trigger_error("变量值必须小于等于 1",E_USER_WARNING); } ?>위 코드의 출력은 다음과 같습니다.
오류: [512] 변수 값은 1보다 작거나 같아야 합니다
이미 홈페이지 관리자에게 알림
위 코드에서 받은 이메일은 다음과 같습니다.
오류: [512] 변수 값은 다음과 같아야 합니다. 1보다 작거나 같음이 방법은 모든 오류에 적합하지 않습니다. 일반 오류는 기본 PHP 로깅 시스템을 사용하여 서버에 기록되어야 합니다.