PHP 오류 처리
PHP 오류 처리
PHP에서 기본 오류 처리는 매우 간단합니다. 파일 이름, 줄 번호 및 오류를 설명하는 메시지와 함께 오류 메시지가 브라우저로 전송됩니다.
PHP 오류 처리
오류 처리는 스크립트와 웹 애플리케이션을 만들 때 중요한 부분입니다. 코드에 오류 감지 코딩이 없으면 프로그램이 비전문적으로 보이고 보안 위험이 발생할 수 있습니다.
이 튜토리얼에서는 PHP에서 가장 중요한 오류 감지 방법 중 일부를 다룹니다.
다양한 오류 처리 방법을 설명해 드리겠습니다. 🎜>· 오류 보고
기본 오류 처리: die() 함수 사용
첫 번째 예는 텍스트 파일을 여는 간단한 스크립트를 보여줍니다.
<?php $file=fopen("welcome.txt","r"); ?>
파일이 없으면 다음과 같은 오류가 발생합니다.
경고: fopen(welcome.txt) [function .fopen]: 스트림을 열지 못했습니다:
2번째 줄의 /www/runoob/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)
오류 보고 수준 이러한 오류 보고 수준은 사용자 정의 오류 처리기가 처리하는 다양한 오류 유형입니다.이제 처리할 함수를 만들어 보겠습니다.
오류:
function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr<br>"; echo "脚本结束"; 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); ?>
위 코드의 출력은 다음과 같습니다.
Error : [8] 정의되지 않은 변수: test
Trigger Error
스크립트에서 사용자가 데이터를 입력하는 시점에서 다음과 같은 경우 오류를 트리거하는 것이 유용합니다. 사용자의 입력이 유효하지 않습니다. PHP에서 이 작업은 Trigger_error() 함수에 의해 수행됩니다.
예
이 예에서 "test" 변수가 "1"보다 크면 오류가 발생합니다.
<?php
$ test=2;
if ($test>1)
{
Trigger_error("변수 값은 1보다 작거나 같아야 합니다.");
}
?>
위 코드의 출력은 다음과 같습니다.
주의: 변수 값은 1보다 작거나 같아야 합니다.
5번째 줄의 /www/test/runoob.php
두 번째 매개변수를 추가하면 발생하는 오류 수준을 지정할 수 있습니다.
가능한 오류 유형:
E_USER_ERROR - 치명적인 사용자 생성 런타임 오류입니다. 오류를 복구할 수 없습니다. 스크립트 실행이 중단되었습니다.
· E_USER_WARNING - 치명적이지 않은 사용자 생성 런타임 경고입니다. 스크립트 실행이 중단되지 않습니다.
· E_USER_NOTICE - 기본값. 사용자가 생성한 런타임 알림. 스크립트가 가능한 오류를 발견할 때 발생하지만 스크립트가 정상적으로 실행될 때도 발생할 수 있습니다.
예
이 예에서는 "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는 php.ini의 error_log 구성에 따라 오류 기록을 서버의 로깅 시스템이나 파일로 보냅니다. 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 로깅 시스템을 사용하여 서버에 기록되어야 합니다.