올바른 쓰기:
1. PHP 오류를 처리하는 세 가지 방법 방법 1, 간단한 die() 문; 종료()와 동일합니다. 예:
간결하게 작성:
방법 2, 오류 및 오류 트리거 사용자 정의 1. 오류 처리기(사용자 정의 오류, 일반적으로 구문 오류 처리에 사용됨) 최소 2개의 매개변수(error_level 및 errormessage)를 처리할 수 있어야 하지만 최대 5개의 매개변수(error_file, error_line, 오류_컨텍스트) 문법: 함수 error_function($error_level,$error_message,$error_file,$error_line,$error_context) //생성 후에는 set_error_handler() 함수를 다시 작성해야 합니다. set_error_handler('error_function',E_WARNING); //여기서 error_function은 위에서 생성한 사용자 정의 핸들러 이름에 해당하고 두 번째 매개변수는 사용자 정의 오류 핸들러를 사용하는 오류 수준입니다. 오류신고 수준 (그냥 이해해주세요) 이러한 오류 보고 수준은 오류 처리기가 처리하도록 설계된 다양한 오류 유형입니다. 값 상수 설명 2 E_WARNING 치명적이지 않은 런타임 오류입니다. 스크립트 실행을 일시 중지하지 마십시오. 8 E_공지사항 런타임 알림. 스크립트 검색 오류가 발생할 수 있지만 스크립트가 정상적으로 실행되는 동안에도 발생할 수 있습니다. 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 E_STRICT 수준을 제외한 모든 오류 및 경고. (PHP 6.0에서는 E_STRICT가 E_ALL의 일부입니다) 2. 오류 트리거(일반적으로 논리적 오류를 처리하는 데 사용됨) 요구사항: 예를 들어 나이를 받고자 할 때 그 숫자가 120보다 크면 오류로 간주됩니다. 전통적인 방법:
set_error_handler('myerror',E_USER_WARNING);//위와 동일하며 첫 번째 매개변수는 사용자 정의 함수의 이름이고 두 번째 매개변수는 오류 수준입니다. [여기서 오류 수준은 일반적으로 다음 세 가지입니다. :E_USER_WARNING, E_USER_ERROR, E_USER_NOTICE] //이제 Trigger_error를 사용하여 사용자 정의 오류 처리 기능을 사용할 수 있습니다. 연습문제:
방법 3, 오류 로그 기본적으로 php.ini의 error_log 구성에 따라 php는 오류 기록을 서버의 오류 기록 시스템이나 파일로 보냅니다. error_log() 함수를 사용하여 오류 기록을 파일이나 원격 대상으로 보낼 수 있습니다. 문법: error_log(오류[,유형,대상,헤더]) 유형 부분은 일반적으로 3을 사용하는데, 이는 원본 내용을 덮어쓰지 않고 파일 끝에 오류 정보를 추가한다는 의미입니다. 대상은 대상, 즉 저장된 파일 또는 원격 대상을 나타냅니다. 예: error_log(“$error_info”,3,”errors.txt”); 2. PHP 예외 처리 1. 기본 문법
2. 처리 프로그램에는 다음이 포함되어야 합니다. Try - 예외를 사용하는 함수는 "try" 블록 안에 있어야 합니다. 예외가 트리거되지 않으면 코드는 평소대로 계속 실행됩니다. 그러나 예외가 트리거되면 예외가 발생합니다. Throw – 예외를 트리거하는 방법을 지정합니다. 각 "던지기"는 적어도 하나의 "잡기"와 일치해야 합니다. Catch – "catch" 코드 블록은 예외를 포착하고 예외 정보가 포함된 객체를 생성합니다 예외 트리거:
위 코드는 다음과 같은 오류를 보고합니다. 메시지: 값은 1 이하여야 합니다 설명: 위 코드는 예외를 발생시키고 이를 포착합니다. checkNum() 함수를 만듭니다. 숫자가 1보다 큰지 여부를 감지합니다. 그렇다면 예외를 발생시킵니다. "try" 블록에서 checkNum() 함수를 호출합니다. checkNum() 함수에서 예외가 발생했습니다. "catch" 코드 블록은 예외를 수신하고 예외 정보가 포함된 객체($e)를 생성합니다. 이 예외 객체에서 $e->getMessage()를 호출하여 이 예외의 오류 메시지를 출력합니다. 그러나 "모든 throw는 catch와 일치해야 합니다"라는 원칙을 따르려면 누락된 오류를 처리하도록 최상위 예외 처리기를 설정할 수 있습니다. set_Exception_handler() 함수는 포착되지 않은 모든 예외를 처리하는 사용자 정의 함수를 설정할 수 있습니다.
사용자 정의 예외 클래스 만들기
여러 캐치를 사용하여 다양한 상황에서 오류 정보를 반환할 수 있습니다.
예외 사용 규칙: 1. 예외 처리가 필요한 코드를 try 코드 블록에 넣어 잠재적인 예외를 포착합니다. 2. 각 try 또는 throw 코드 블록에는 해당하는 catch 코드 블록이 하나 이상 있어야 합니다. 3. 여러 catch 코드 블록을 사용하여 다양한 유형의 예외를 포착합니다. 4. try 코드 내의 catch 코드 블록에서 예외가 다시 발생될 수 있습니다. 한 문장을 기억하세요. 예외가 발생하면 이를 잡아야 합니다. |