PHP 오류
PHP에서는 기본 오류 처리가 간단합니다. 파일 이름, 줄 번호 및 오류를 설명하는 메시지와 함께 오류 메시지가 브라우저로 전송됩니다.
PHP 오류 처리
오류 처리는 스크립트 및 웹 애플리케이션을 만들 때 중요한 부분입니다. 코드에 오류 감지 코딩이 없으면 프로그램이 비전문적으로 보이고 보안 위험이 발생할 수 있습니다.
이 튜토리얼에서는 PHP에서 가장 중요한 오류 감지 방법 중 일부를 다룹니다.
다양한 오류 처리 방법을 설명해 드리겠습니다.
간단한 "die()" 문
오류 정의 이후 및 오류 트리거
오류 보고
기본 오류 처리: die() 함수 사용
첫 번째 예 텍스트 파일을 여는 간단한 스크립트는 다음과 같습니다.
<?php $file=fopen("welcome.txt","r"); ?>파일이 없으면 다음과 같은 오류가 발생합니다.
Warning: fopen(welcome.txt) [function.fopen]: failed to open stream: No such file or directory in /www/php/test/test.php on line 2사용자가 위와 같은 오류 메시지를 받으면 파일에 액세스하기 전에 파일이 있는지 확인합니다.
<?php if(!file_exists("welcome.txt")) { die("文件不存在"); } else { $file=fopen("welcome.txt","r"); } ?>이제 파일이 없으면 다음과 같은 오류 메시지가 표시됩니다.
이전 코드에 비해 위 코드는 간단한 오류 처리 메커니즘을 사용하므로 더 효율적입니다. 스크립트가 종료되었습니다. 오류 후.
그러나 단순히 스크립트를 종료하는 것이 항상 적절한 것은 아닙니다. 오류 처리를 위한 대체 PHP 함수를 살펴보겠습니다.
사용자 정의 오류 핸들러 생성
사용자 정의 오류 핸들러를 생성하는 것은 매우 쉽습니다. PHP에서 오류가 발생할 때 호출할 수 있는 전용 함수를 간단히 만들었습니다.
함수는 최소 2개의 매개변수(오류 수준 및 오류 메시지)를 처리할 수 있어야 하지만 최대 5개의 매개변수(선택 사항: 파일, 줄 번호 및 오류 컨텍스트)를 허용할 수 있습니다.
문법
参数 | 描述 |
---|---|
error_level | 必需。为用户定义的错误规定错误报告级别。必须是一个数字。参见下面的表格:错误报告级别。 |
error_message | 必需。为用户定义的错误规定错误消息。 |
error_file | 可选。规定错误发生的文件名。 |
error_line | 可选。规定错误发生的行号。 |
error_context | 可选。规定一个数组,包含了当错误发生时在用的每个变量以及它们的值。 |
오류 보고 수준
이러한 오류 보고 수준은 사용자 정의 오류 처리기가 처리하는 다양한 유형의 오류입니다.
值 | 常量 | 描述 |
---|---|---|
2 | E_WARNING | 非致命的 run-time 错误。不暂停脚本执行。 |
8 | E_NOTICE | run-time 通知。在脚本发现可能有错误时发生,但也可能在脚本正常运行时发生。 |
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 的一部分) |
이제 오류를 처리하는 함수를 만들어 보겠습니다.
error_function(error_level,error_message, error_file,error_line,error_context)위 코드는 간단한 오류 처리 함수입니다. 트리거되면 오류 수준과 오류 메시지가 표시됩니다. 그런 다음 오류 수준과 메시지를 인쇄하고 스크립트를 종료합니다.
이제 오류 처리 함수를 만들었으므로 함수를 실행할 시점을 결정해야 합니다.
오류 핸들러 설정
PHP의 기본 오류 핸들러는 내장된 오류 핸들러입니다. 스크립트가 실행될 때 위 함수를 기본 오류 처리기로 변환하겠습니다.
오류 핸들러를 수정하여 특정 오류에만 적용하면 스크립트가 다양한 오류를 다양한 방식으로 처리할 수 있습니다. 그러나 이 경우 모든 오류에 대해 사용자 정의 오류 핸들러를 사용하려고 합니다.
function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr<br>"; echo "脚本结束"; die(); }
사용자 정의 함수가 모든 오류를 처리하도록 하기 때문에 set_error_handler()에는 하나의 인수만 필요하며 두 번째 매개변수를 추가할 수 있습니다. 오류 수준을 지정합니다.
예
존재하지 않는 변수를 출력하여 이 오류 핸들러를 테스트합니다.
set_error_handler("customError");
Trigger Error
스크립트에서 사용자가 데이터를 입력하는 시점에서 사용자의 입력이 유효하지 않을 때 오류를 발생시키는 것이 유용합니다. PHP에서 이 작업은 Trigger_error() 함수에 의해 수행됩니다.
예
이 예에서 "test" 변수가 "1"보다 크면 오류가 발생합니다.
<?php// 错误处理函数function customError($errno, $errstr){echo "<b>Error:</b> [$errno] $errstr";}// 设置错误处理函数set_error_handler("customError");// 触发错误echo($test);?> 以上代码的输出如下所示: Error: [8] Undefined variable: test위의 출력 코드는 다음과 같습니다.
<?php $test=2; if ($test>1) { trigger_error("变量值必须小于等于 1"); } ?>두 번째 매개변수를 추가하면 트리거되는 오류 수준을 지정할 수 있습니다.
가능한 오류 유형:
E_USER_ERROR - 치명적인 사용자 생성 런타임 오류입니다. 오류를 복구할 수 없습니다. 스크립트 실행이 중단되었습니다.
E_USER_WARNING - 치명적이지 않은 사용자 생성 런타임 경고입니다. 스크립트 실행이 중단되지 않습니다.
E_USER_NOTICE - 기본값. 사용자가 생성한 런타임 알림. 스크립트가 가능한 오류를 발견할 때 발생하지만 스크립트가 정상적으로 실행될 때도 발생할 수 있습니다.
예제
이 예에서는 "test" 변수가 "1"보다 크면 E_USER_WARNING 오류가 발생합니다. E_USER_WARNING이 발생하면 사용자 정의 오류 처리기를 사용하고 스크립트를 종료합니다.
Notice: 变量值必须小于等于 1 in /www/test/php.php on line 5위 코드의 출력은 다음과 같습니다.
<?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); } ?>이제 오류를 생성하는 방법과 이를 트리거하는 방법을 배웠으므로 오류 로깅을 살펴보겠습니다.
오류 로깅
기본적으로 PHP는 php.ini의 error_log 구성에 따라 서버의 로깅 시스템이나 파일에 오류 로깅을 보냅니다. error_log() 함수를 사용하면 오류 기록을 지정된 파일이나 원격 대상으로 보낼 수 있습니다.
자신에게 오류 메시지를 이메일로 보내는 것은 특정 오류에 대한 알림을 받을 수 있는 좋은 방법입니다.
이메일로 오류 메시지 보내기
아래 예에서 특정 오류가 발생하면 오류 메시지가 포함된 이메일을 보내고 스크립트를 종료합니다.
Error: [512] 变量值必须小于等于 1 脚本结束위 코드의 출력은 다음과 같습니다.
<?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); } ?>이 방법은 모든 오류에 적합하지 않습니다. 일반 오류는 기본 PHP 로깅 시스템을 사용하여 서버에 기록되어야 합니다.