1. 오류 및 예외 처리
1.1 오류 유형 및 기본 디버깅 방법
??PHP 프로그램 오류의 일반적인 원인 다음 세 가지 영역:
?? 문법 오류:
?? 문법 오류는 가장 일반적이며 수정하기 쉽습니다. 예: 코드에 세미콜론이 없습니다. 이러한 오류로 인해 스크립트가 실행되지 않습니다.
?? 런타임 오류:
?? 이 오류는 일반적으로 PHP 스크립트 실행을 방해하지는 않지만 현재 수행 중인 작업을 방해합니다. . 오류가 출력되는데 php 스크립트가 계속 실행됩니다.
?? 논리 오류:
?? 이런 오류가 제일 문제네요. 스크립트가 실행되는 것을 방지하지도 않고 오류 메시지가 출력되지도 않습니다.
?? 예외는 프로그램 실행 중에 발생하는 예외 또는 일반적인 명령어의 실행을 중단하고 실행을 계속하기 위해 다른 프로그램 모듈로 점프하는 이벤트입니다.
PHP 오류 보고 수준
??E_ALL //모든 정보 값: 6143
??E_ERROR// 치명적 런타임 오류 값: 1
??E_RECOVERABLE_ERROR //치명에 가까운 런타임 오류가 발견되지 않으면 E_ERROR로 처리됩니다. 값: 4096
? /런타임 경고(치명적이지 않은 오류) 값: 2
??E_PARSE //컴파일 시간 구문 분석 오류 값: 4
??E_NOTICE / / 런타임 알림(종종 버그, 의도적일 수도 있음) 값: 8
??E_STRICT // 코딩 표준화 경고(향후 호환성을 위해 수정 방법 권장) 값: 2048
??E_CORE_ERROR //PHP 시작 시 초기화 과정 중 치명적인 오류 값: 16
??E_CORE_WARNING //PHP 시작 시 초기화 과정 중 경고(치명적이지 않은 오류) 값: 32
??E_COMPILE_ERROR //컴파일 시간 치명적 오류 값: 64
??E_COMPILE_WARNING //컴파일 시간 경고(치명적이지 않은 오류) 값:128
??E_USER_ERROR //사용자 정의 치명적 오류 값: 256
??E_USER_WARNING //사용자 정의 경고(심각하지 않은 오류) 값: 512
??E_USER_NOTICE //사용자 정의 알림(종종 버그) 값: 1024
php.ini 구성 파일
display_errors: PHP가 오류 보고서를 출력하도록 활성화할지 여부
?? 값은 On(기본 오류 보고서 출력), Off(모든 오류 메시지 차단)
??php.ini 구성 파일을 동적으로 설정하기 위해 PHP 스크립트에서 ini_set() 함수를 호출할 수 있습니다.
??예: ini_set("display_errors","On " ); //모든 오류 메시지 표시
??error_reporting: 다양한 오류 보고 수준을 설정합니다.
??error_reporting= E_ALL & ~E_NOTICE
--눈에 띄지 않는 오류가 발생할 수 있습니다. 기본값
error_reporting = E_ERROR | E_PARSE | E_CORE_ERROR
--치명적인 런타임 오류, 새로운 구문 분석 오류 및 핵심 오류만 고려됩니다.
??error_reporting= E_ALL & ~(E_USER_ERROR | E_USER_WARNING | E_USER_NOTICE)
--사용자로 인해 발생한 오류를 제외한 모든 오류를 보고합니다.
?? PHP 스크립트에서는 error_reporting() 함수를 통해 오류 보고 수준을 동적으로 설정할 수 있습니다. 예: error_reporting(E_ALL);]
오류 수준 설정 예: error.php
<span><h2>测试错误报告</h2> <?<span>php </span><span>/*</span><span>开启php.ini中的display_errors指令,只有该指令开启如有错误报告才能输出</span><span>*/</span><span>ini_set(</span><span>'</span><span>display_errors</span><span>'</span>,<span>1</span><span>); </span><span>/*</span><span>通过error_reporting()函数设置在本脚本中,输出所有级别的错误报告</span><span>*/</span><span>error_reporting(E_ALL); </span><span>/*</span><span>“注意(notice)”的报告,不会阻止脚本的执行,并且不一定是一个问题</span><span>*/</span><span>getType($</span><span>var</span>);<span>//</span><span>调用函数时提供的参数变量没有在之前声明</span><span>/*</span><span>“警告(warning)”的报告,指示一个问题,但是不会阻止脚本的执行</span><span>*/</span><span>getType();</span><span>//</span><span>调用函数时没有提供必要的参数</span><span>/*</span><span>“错误(error)”的报告,它会终止程序,脚本不会再向下执行</span><span>*/</span><span>get_Type();</span><span>//</span><span>调用一个没有被定义的函数</span>?></span>
오류 보고 동작을 위한 PHP 구성 지시문
display_startup_errors= Off
초기화 중에 PHP 엔진에서 발생한 오류를 표시할지 여부.
??log_errors=On
??로그문이 기록되는 위치를 결정합니다.
??error_log (기본값은 null)
??오류가 기록되는 파일을 지정하거나 시스템 로그 syslog에 오류 로그를 기록합니다.
??Log_errors_max_len=1024
??각 로그 항목의 최대 길이(바이트)입니다. 0은 최대를 의미합니다.
1.2 오류 로그
오류 로그를 기록하는 두 가지 방법:
지정된 파일 기록을 사용합니까? 오류 보고 로그
??오류 로그는 운영체제 로그에 기록됩니다
지정된 파일을 사용하여 오류 보고 로그를 기록합니다
1. 먼저 php.ini를 구성합니다:
??error_reporting= E_ALL//모든 오류는 PHP로 전송됩니다
?? display_errors=Off //오류 보고서를 표시하지 않습니다
??log_errors=On//로그 문이 기록되는 위치를 결정합니다.
??log_errors_max_log=1024//각 로그 항목의 최대 길이
??error_log=G:/myerror.log//오류가 있는 파일 지정 작성
?? 2. 함수 사용 : php 파일에 error_log()를 사용하여 로그를 기록하고, 해당 정보를 myerror.log 파일에 기록할 수 있습니다
? ?예: error_log("로그인 실패!");
2. 네 가지 함수를 사용하여 로그를 기록합니다.
??define_syslog_variables(); //시스템 로그 구성 초기화
??openlog();//로그 링크 열기
??syslog();//로그 보내기
예
<span><?<span>php </span><span>if</span>(!<span>Ora_Logon($username, $password)){ error_log(</span><span>"</span><span>Oracle数据库不可用!</span><span>"</span>, <span>0</span><span>); </span><span>//</span><span>将错误消息写入到操作系统日志中</span><span>} </span><span>if</span>(!($foo=<span>allocate_new_foo()){ error_log(</span><span>"</span><span>出现大麻烦了!</span><span>"</span>, <span>1</span>, <span>"</span><span>webmaster@www.mydomain.com</span><span>"</span>); <span>//</span><span>发送到管理员邮箱中</span><span>} error_log(</span><span>"</span><span>搞砸了!</span><span>"</span>,<span>2</span>, <span>"</span><span>localhost:5000</span><span>"</span><span>); </span><span>//</span><span>发送到本机对应5000端口的服务器中</span>error_log(<span>"</span><span>搞砸了!</span><span>"</span>, <span>3</span>, <span>"</span><span>/usr/local/errors.log</span><span>"</span><span>); </span><span>//</span><span>发送到指定的文件中</span>?></span>
<span><?<span>php define_syslog_variables(); openlog(</span><span>"</span><span>PHP5</span><span>"</span><span>, LOG_PID , LOG_USER); syslog(LOG_WARNING, </span><span>"</span><span>警告报告向syslog中发送的演示,警告时间:</span><span>"</span>.date(<span>"</span><span>Y/m/dH:i:s</span><span>"</span><span>)); closelog(); </span>?></span>
로그 보기: 예를 들어 Windows 시스템에서는 "내 컴퓨터"를 마우스 오른쪽 버튼으로 클릭 -> 관리 옵션 선택 -> 시스템 도구 메뉴에서 이벤트 뷰어 선택 -> 애플리케이션 옵션 로그할 시간입니다
1.3 예외 처리
예외 처리는 다음과 같은 경우 스크립트의 일반적인 동작을 변경하는 데 사용됩니다. 지정된 오류가 발생합니다. 이는 PHP5의 중요한 새로운 기능입니다. 예외 처리는 확장 가능하고 유지 관리가 쉬운 오류 처리 통합 메커니즘이며, 새로운 객체 지향 오류 처리 방법을 제공합니다.
??예외 처리 형식:
try{
try를 사용하여 예외가 발생할 수 있는 코드를 포함하세요.
예외가 발생하면 예외를 catch하고 처리를 위해 catch에 넘겨줍니다.
예외 발생 문: 예외 개체를 발생시킵니다.
}catch(예외 객체 매개변수) {
여기에서 예외 처리를 수행합니다.
}[잡기(.,,){
.. .. ..
}]
위 내용을 포함하여 PHP_Error 및 Exception Handling - php(32)의 공통 기능 블록을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.