예외는 지정된 오류가 발생할 때 스크립트의 일반적인 흐름을 변경하는 데 사용됩니다.
PHP 5는 오류 처리에 대한 새로운 객체 지향 접근 방식을 제공합니다.
예외 처리는 지정된 오류(예외) 조건이 발생할 때 스크립트의 일반적인 흐름을 변경하는 데 사용됩니다. 이러한 상황을 예외라고 합니다.
예외가 트리거되면 일반적으로 다음과 같은 일이 발생합니다.
현재 코드 상태가 저장됩니다.
코드 실행이 사전 정의된(사용자 정의) 예외 처리기 기능으로 전환됩니다.
상황에 따라 프로세서는 저장된 코드 상태에서 코드 실행을 다시 시작하거나, 스크립트 실행을 종료하거나, 코드의 다른 위치에서 스크립트 실행을 계속할 수 있습니다.
다양한 오류 처리 방법을 보여드리겠습니다.
예외의 기본 사용법
사용자 정의 예외 처리기 만들기
여러 예외
예외 다시 발생
최상위 예외 처리기 설정
참고: 예외는 오류 상황에서만 사용해야 하며 지정된 지점에서 코드의 다른 위치로 이동하는 데 사용해서는 안 됩니다.
예외가 발생하면 다음 코드는 더 이상 실행되지 않으며 PHP는 일치하는 "catch" 코드 블록을 찾으려고 시도합니다.
예외가 catch되지 않고 set_Exception_handler()를 사용하여 적절하게 처리되지 않으면 심각한 오류(치명적 오류)가 발생하고 "Uncaught Exception" 오류 메시지가 출력됩니다.
catch하지 않고 예외를 던져 보겠습니다.
<?php // 예외 처리가 포함된 함수 생성 기능 수표번호 ( $번호 ) { if ( $number > 1 ) { 던지다 새로운 예외 ( " 값 은 1 이하여야 합니다 ." ) } 반품 진실 ; } // 예외 발생 체크넘버 ( 2 ) ? >
위 코드에서는 다음과 유사한 오류가 발생합니다.
치명적인 오류: /www/codercto/test/test.php:7 스택 추적: #0 /www/codercto/test/test.php(13)에서 '값은 1 이하여야 합니다'라는 메시지와 함께 포착되지 않은 예외 '예외': checkNum(2) #1 {main}은 7행의 /www/codercto/test/test.php에 표시됩니다.
위의 예에서 나타나는 오류를 방지하려면 예외를 처리하는 적절한 코드를 만들어야 합니다.
적절한 예외 처리 코드에는 다음이 포함되어야 합니다.
Try - 예외를 사용하는 함수는 "try" 블록 내에 있어야 합니다. 예외가 트리거되지 않으면 코드는 평소대로 계속 실행됩니다. 그러나 예외가 트리거되면 예외가 발생합니다.
Throw - 예외를 트리거하는 방법을 지정합니다. 각 "던지기"는 적어도 하나의 "잡기"와 일치해야 합니다.
Catch - "catch" 블록은 예외를 포착하고 예외 정보가 포함된 객체를 생성합니다.
예외를 발생시키자:
<?php // 예외 처리 기능이 있는 함수를 만듭니다. 기능 수표번호 ( $번호 ) { if ( $number > 1 ) { 던지다 새로운 예외 ( " 변수 값 은 1보다 작거나 같아야 합니다 . " ) } 반품 진실 ; } // try 블록에서 예외를 발생시킵니다. 노력하다 { checkNum ( 2 ) ; // 예외가 발생하면 다음 텍스트가 출력되지 않습니다. 에코 ' 이 내용이 출력된다면 $number 변수를 설명해주세요 . ' } // 예외 잡기 잡기 ( 예외 $e ) { 에코 ' 메시지 : ' . $e -> getMessage ( ) ; ?>
위 코드에서는 다음과 유사한 오류가 발생합니다.
메시지: 변수 값은 1보다 작거나 같아야 합니다.
위의 코드는 예외를 발생시키고 이를 포착합니다.
checkNum() 함수를 만듭니다. 숫자가 1보다 큰지 여부를 감지합니다. 그렇다면 예외를 발생시킵니다.
"try" 블록에서 checkNum() 함수를 호출합니다.
checkNum() 함수에서 예외가 발생합니다.
"catch" 코드 블록은 예외를 수신하고 예외 정보가 포함된 객체($e)를 생성합니다.
이 예외 객체에서 $e->getMessage()를 호출하여 이 예외의 오류 메시지를 출력합니다.
그러나 "모든 throw는 catch와 일치해야 합니다"라는 원칙을 따르기 위해 누락된 오류를 처리하도록 최상위 예외 처리기를 설정할 수 있습니다.
사용자 정의 예외 처리기를 만드는 것은 매우 간단합니다. 우리는 PHP에서 예외가 발생할 때 함수를 호출할 수 있는 특수 클래스를 만들었습니다. 이 클래스는 예외 클래스의 확장이어야 합니다.
이 사용자 정의 customException 클래스는 PHP 예외 클래스의 모든 속성을 상속하며 여기에 사용자 정의 기능을 추가할 수 있습니다.
customException 클래스를 생성하는 것부터 시작합니다.
<?php 수업 맞춤 예외 연장 예외 { 공공의 기능 오류 메시지 ( ) { // 오류 메시지 $ errorMsg = ' 오류 행 번호 ' . $ this - > getLine ( ) . $ this - > getMessage ( ) . 유효한 이메일 주소 ' ; $오류 메시지 } } $email = " someone@ example ...com " ; { // 이메일 감지 if ( 필터_var ( $email , FILTER_VALIDATE_EMAIL ) === FALSE ) { // 잘못된 이메일 주소인 경우 예외 발생 던지다 새로운 customException ( $ email ) } } 잡다 ( 맞춤예외 $e ) { // 사용자 정의 메시지 표시 에코 $e -> 오류 메시지 ( ) } ?>
이 새 클래스는 이전 예외 클래스의 복사본과 errorMessage() 함수입니다. 기존 클래스의 복사본이기 때문에 기존 클래스의 속성과 메서드를 상속받으며, getLine(), getFile(), getMessage() 등 예외 클래스의 메서드를 사용할 수 있습니다.
위의 코드는 예외를 발생시키고 사용자 정의 예외 클래스를 통해 이를 포착합니다.
customException() 클래스는 이전 예외 클래스의 확장으로 생성되었습니다. 이런 방식으로 이전 예외 클래스의 모든 속성과 메서드를 상속합니다.
errorMessage() 함수를 만듭니다. 이메일 주소가 유효하지 않으면 이 함수는 오류 메시지를 반환합니다.
$email 변수를 잘못된 이메일 주소 문자열로 설정하십시오.
"try" 코드 블록이 실행되고 이메일 주소가 유효하지 않기 때문에 예외가 발생합니다.
"catch" 코드 블록은 예외를 포착하고 오류 메시지를 표시합니다.
여러 상황을 감지하기 위해 스크립트에 여러 예외를 사용할 수 있습니다.
여러 if..else 코드 블록을 사용하거나 스위치 코드 블록을 사용하거나 여러 예외를 중첩할 수 있습니다. 이러한 예외는 다른 예외 클래스를 사용하고 다른 오류 메시지를 반환할 수 있습니다.
<?php 수업 맞춤 예외 연장 예외 { 공공의 기능 오류 메시지 ( ) { // 오류 메시지 $ errorMsg = ' 오류 행 번호 ' . $ this - > getLine ( ) . $ this - > getMessage ( ) . 유효한 이메일 주소 ' ; $오류 메시지 } } $ email = " [email protected] " ; { // 이메일 감지 if ( 필터_var ( $email , FILTER_VALIDATE_EMAIL ) === FALSE ) { // 잘못된 이메일 주소인 경우 예외 발생 던지다 새로운 customException ( $ email ) } // 이메일 주소에 "example"이 있는지 확인 if ( strpos ( $email , " 예제 " ) !== FALSE ) { 던지다 새로운 예외 ( " $email은 예시 메일박스입니다 . " ) ; } 잡다 ( 맞춤예외 $e ) { 에코 $e -> 오류 메시지 ( ) } 잡기 ( 예외 $e ) { 에코 $e - > getMessage ( ) } ?>
위의 코드는 두 가지 조건을 테스트하고 두 조건 중 하나가 true가 아닌 경우 예외를 발생시킵니다.
customException() 클래스는 이전 예외 클래스의 확장으로 생성되었습니다. 이런 방식으로 이전 예외 클래스의 모든 속성과 메서드를 상속합니다.
errorMessage() 함수를 만듭니다. 이메일 주소가 유효하지 않으면 이 함수는 오류 메시지를 반환합니다.
$email 변수를 유효한 이메일 주소이지만 "example"이라는 문자열을 포함하는 문자열로 설정합니다.
코드의 "try" 블록을 실행하면 첫 번째 조건에서는 예외가 발생하지 않습니다.
이메일에 "example" 문자열이 포함되어 있으므로 두 번째 조건은 예외를 트리거합니다.
"catch" 블록은 예외를 포착하고 적절한 오류 메시지를 표시합니다.
customException 클래스가 예외를 발생시켰지만 customException이 포착되지 않은 경우 기본 예외만 포착되고 거기서 예외가 처리됩니다.
때로는 예외가 발생하면 표준과 다르게 처리해야 할 수도 있습니다. 예외는 "catch" 블록에서 다시 발생할 수 있습니다.
스크립트는 사용자에게 시스템 오류를 숨겨야 합니다. 시스템 오류는 프로그래머에게 중요할 수 있지만 사용자는 이에 관심이 없습니다. 사용자가 더 쉽게 작업할 수 있도록 사용자에게 친숙한 메시지를 사용하여 예외를 다시 발생시킬 수 있습니다.
<?php 수업 맞춤 예외 연장 예외 { 공공의 기능 오류 메시지 ( ) { // 오류 메시지 $errorMsg = $this -> getMessage ( ) ' 유효한 이메일 주소가 아닙니다 . ' ; 반품 $오류 메시지 } } $ email = " [email protected] " ; { 노력하다 { // 이메일 주소에 "example"이 있는지 확인 if ( strpos ( $email , " 예제 " ) !== FALSE ) { // 잘못된 이메일 주소인 경우 예외 발생 던지다 새로운 예외 ( $ email ) } } 잡기 ( 예외 $e ) { // 예외를 다시 발생시킵니다. 던지다 새로운 customException ( $ email ) } } 잡다 ( 맞춤예외 $e ) { // 사용자 정의 정보 표시 에코 $e -> 오류 메시지 ( ) } ?>
위의 코드는 이메일 주소에 "example"이라는 문자열이 포함되어 있는지 여부를 감지합니다. 그렇다면 예외를 다시 발생시킵니다.
customException() 클래스는 이전 예외 클래스의 확장으로 생성되었습니다. 이런 방식으로 이전 예외 클래스의 모든 속성과 메서드를 상속합니다.
errorMessage() 함수를 만듭니다. 이메일 주소가 유효하지 않으면 이 함수는 오류 메시지를 반환합니다.
$email 변수를 유효한 이메일 주소이지만 "example"이라는 문자열을 포함하는 문자열로 설정합니다.
"try" 블록에는 예외가 다시 발생할 수 있도록 또 다른 "try" 블록이 포함되어 있습니다.
전자 메일에 "example"이라는 문자열이 포함되어 있으므로 예외가 발생합니다.
"catch" 코드 블록은 예외를 포착하고 "customException"을 다시 발생시킵니다.
"customException"이 발견되고 오류 메시지가 표시됩니다.
현재 "try" 블록에서 예외가 포착되지 않으면 더 높은 수준에서 catch 블록을 찾습니다.
set_Exception_handler() 함수는 포착되지 않은 모든 예외를 처리하는 사용자 정의 함수를 설정합니다.
<?php 기능 myException ( $예외 ) { 에코 " <b>예외:</b> " , $ Exception -> getMessage ( ) } set_Exception_handler ( ' myException ' ) ; 새로운 Exception ( ' 포착되지 않은 예외가 발생했습니다 .' ) ? >
위 코드의 출력은 다음과 같습니다.
예외: 포착되지 않은 예외가 발생했습니다.
위 코드에는 "catch" 블록이 없으며 대신 최상위 예외 처리기가 트리거됩니다. 이 함수는 포착되지 않은 모든 예외를 포착하는 데 사용해야 합니다.
예외 처리가 필요한 코드는 잠재적인 예외를 포착하기 위해 try 블록 내에 배치되어야 합니다.
각 try 또는 throw 블록에는 해당하는 catch 블록이 하나 이상 있어야 합니다.
여러 종류의 예외를 포착하려면 여러 catch 블록을 사용하세요.
try 블록 내의 catch 블록에서 예외가 발생(다시 발생)될 수 있습니다.
간단히 말해서, 예외가 발생하면 이를 잡아야 합니다.