이 글은 PHP 프로그래머들이 겪는 오류와 예외를 소개합니다. 이제 여러분과 공유합니다. 도움이 필요한 친구들이 참고할 수 있습니다
PHP 오류와 예외는 서로 다른 개념입니다
세미콜론 누락과 같은 구문 오류
권한, 파일 열기 실패, 데이터베이스 서버 사용 불가와 같은 환경 오류
a= =b와 같은 논리 오류는 다음과 같이 기록됩니다. a=b
Deprecated
최하위 수준 오류(비추천, 권장되지 않음, 예를 들어 일반 ereg( )의 이전 버전)
함수는 대체될 수 있으며 PHP 실행에는 영향을 미치지 않습니다) Depracated
最低级别的错误 (deprecated不建议,不推荐,如老版本的正则ereg()
函数换掉即可,并不影响PHP的执行)
Notice
通知级别的错误(语法不恰当导致的,不影响PHP的正常运行,如打印一个未定义的变量,所以我们一开始就要养成良好的书写规范)
Warning
警告级别的错误(必须修改代码)
Fatal error
致命级别的错误,程序会停止
Parse error
语法解析错误,在代码运行前检查,将无法执行代码
E_USER_相关的错误
由用户定义的错误,手动抛出错误时会用到
error_reporting=E_ALL & ~E_NOTICE # 显示所有但不显示提醒错误 display_errors = Off|On # 是否显示错误,线上后关闭提高用户体验
error_reporting() # 专业php错误处理设置函数,动态设置错误级别 error_reporting(0) # 不显示所有错误,但是解析parse语法错误会显示 error_reporting(-1) # 显示所有错误 Error_reporting(E_ALL|~E_WARING) # 除了警告错误以外的错误级别都报告
ini_set(option,value) ini_set(error_reporting,0) ini_set(error_reporting,-1) ini_set(error_reporting,E_ALL) ini_set(display_errors,0) ini_set(display_errors,OFF/0) error_reporting(-1);
@
错误抑制符,放在行首不显示该行错误
手动抛出自定义错误信息:trigger_error('错误提示内容',E_USER_NOTICE)
错误级别:
E_USER_NOTICE # 继续执行(通知级别) E_USER_WARNING # 继续执行(警告错误) E_USER_ERROR # 程序不再执行(致命错误)
ini_set('display_errors','off') # 不显示错误给用户 ini_set("error_log","c:\error.log"); error_reporting(-1); # 显示所有错误
ini_set("error_log", 'syslog')
error_log("this is a errormsg",1,xxxxx@qq.com);
set_error_handler("自定义函数名",'错误级别(选填)') # 设置一个用户定义的错误处理函数 restore_error_handler(); # 回收(取消自定义错误函数接管php系统错误)
class MyErrorHandler{ //错误信息 public $message = ''; //错误文件 public $filename = ''; //错误行号 public $line = 0; //额外信息 public $vars = array(); protected $_noticelog = 'G:\notice\noticeLog.log'; public function __construct($message, $filename, $line, $vars) { $this->message = $message; $this->filename = $filename; $this->line = $line; $this->vars = $vars; } //根据不同错误级别对应不同操作 //遵循handler错误处理原则,errno:错误代码,line:错误行号 public static function deal($errno,$errmsg,$filename,$line,$vars) { $self = new self($errmsg,$filename,$line,$vars); switch ($errno) { case E_USER_ERROR://致命级别 return $self->dealError(); break; case E_USER_WARNING://警告级别 case E_WARNING: return $self->dealWarning(); break; case E_NOTICE://通知级别 case E_USER_NOTICE: return $self->dealNotice(); break; default: return false; } } /** * 如何处理致命错误 */ public function dealError() { //开启内存缓冲 ob_start(); //回溯上一条信息 debug_print_backtrace(); $backtrace = ob_get_flush(); $errorMsg = <<<EOF 出现了致命错误,如下: 产生错误的文件:{$this->filename} 产生错误的信息:{$this->message} 产生错误的行号:{$this->line} 追踪信息:{$backtrace} EOF; // error_log($errorMsg,1,'xxxx@qq.com'); error_log($errorMsg,3,$this->_noticelog); exit(1); } /** * 如何处理警告错误 */ public function dealWarning() { $errorMsg = <<<EOF 出现了警告错误,如下: 产生警告的文件:{$this->filename} 产生警告的信息:{$this->message} 产生警告的行号:{$this->line} EOF; // return error_log($errorMsg,1,'xxx@qq.com'); return error_log($errorMsg,3,$this->_noticelog); } /** * 如何处理通知错误 */ public function dealNotice() { $datetime = date('Y-m-d H:i:s',time()); $errorMsg = <<<EOF 出现了通知错误,如下: 产生通知的文件:{$this->filename} 产生通知的信息:{$this->message} 产生通知的行号:{$this->line} 产生通知的时间:{$datetime} EOF; return error_log($errorMsg,3,$this->_noticelog); } }
require_once 'MyErrorHandler.php'; error_reporting(-1); //使用MyErrorHandler类直接调用deal方法 /** * set_error_handler(array(类名/new 类名,方法名)); * set_error_handler(函数名); */ set_error_handler(array('MyErrorHandler','deal')); //通知级别错误 echo $test; //警告级别错误 settype($var,'king'); //致命错误 //test(); //总结:手动抛出的信息会被显示在浏览器 trigger_error('我是手动抛出的致命错误',E_USER_ERROR); echo 'this is a test ';
使用场景:
页面强制被停止
程序代码意外终止或超时
register_shutdown_function()
函数是从内存中调用
的,也就是PHP语句执行完之后(页面已不存在了)再调用这个函数,所以写路径的时候已经脱离这个脚本了,所以file_put_contents()
路径要用绝对路径
error_get_last # 得到最后产生的错误
注意:如果在register_shutdown_function()
之前有die/exit
则不会被执行
未完!待续下篇:那些年,PHPer遇到的错误与异常:下篇之异常
알림
알림 수준 오류(부적절한 구문으로 인해 발생하며 다음과 같은 PHP의 정상적인 작동에 영향을 미치지 않습니다) 인쇄 정의되지 않은 변수이므로 처음부터 좋은 작성 습관을 개발해야 합니다)
경고
경고 수준 오류(코드를 수정해야 함)
치명적 오류치명적 수준 오류, 🎜<code>프로그램이 중지됩니다
🎜🎜🎜🎜🎜분석 오류
구문 분석 오류, 코드를 실행하기 전에 확인하세요, 🎜가 실행되지 않습니다.
🎜🎜🎜🎜🎜E_USER_관련 오류
사용자가 정의한 오류, 수동으로 오류를 던질 때 사용🎜🎜🎜🎜1.3 오류 수준 설정 방법🎜trigger_error('error Prompt content',E_USER_NOTICE) 코드 >🎜🎜 <span class="img-wrap"><img src="https://img.php.cn/upload/article/000/153/291/bc95c4ca7986535b3f43e1931936f826-0.png" alt="PHP 프로그래머가 직면한 오류 및 예외 1부 오류" ></span> 🎜🎜 🎜오류 수준: 🎜🎜rrreee🎜 2. PHP에서 오류 처리 🎜🎜2.1 지정된 파일에 오류 로그 저장 🎜rrreee🎜2.2 시스템 로그에 오류 로그 저장 🎜rrreee🎜2.3 오류 로그를 이메일로 보내기 🎜 rrreee🎜3. 사용자 정의 오류 처리기🎜🎜3.1 set_error_handler 사용자 정의 오류 처리🎜rrreee🎜 <span class="img-wrap"><img src="https://img.php.cn/upload/article/000%20/153%20/291/bc95c4ca7986535b3f43e1931936f826-1.png" alt="PHP 프로그래머가 직면한 오류 및 예외 1부 오류" ></span>🎜🎜3.2 사용자 정의 오류 핸들러🎜rrreee🎜3.3 오류 핸들러 테스트🎜rrreee🎜3.4 Register_shutdown_function 사용법🎜🎜 pan class="img-wrap "><img src="https://img.php.cn/upload/article/000/153/291/343353203eb64e8381aa8c57bde2c869-2.png" alt="PHP 프로그래머가 직면한 오류 및 예외 1부 오류" >🎜🎜 🎜사용 시나리오: 🎜🎜🎜🎜🎜 페이지가 강제로 중지되었습니다. 🎜🎜🎜🎜프로그램 코드가 예기치 않게 종료되거나 시간이 초과되었습니다🎜🎜🎜🎜 /291/343353203eb64e8381aa8c57bde2c869-3.png"/>🎜🎜 <code>register_shutdown_function()
함수는 🎜 메모리에서 호출
🎜, 즉 PHP 문이 실행됩니다. 이 함수는 나중에 호출되므로(페이지가 더 이상 존재하지 않음) 경로를 작성할 때 이미 스크립트에서 벗어났으므로 file_put_contents( )
🎜경로는 절대 경로를 사용해야 합니다
🎜🎜 rrreee🎜 🎜참고: 🎜register_shutdown_function() 앞에 <code>die/exit
가 있는 경우 code>, 실행되지 않습니다🎜🎜🎜아직 끝나지 않았습니다! 다음 기사에서 계속: 🎜해당 기간 동안 PHPer에서 발생한 오류 및 예외: 다음 기사의 예외
🎜🎜🎜참조 과정 비디오: 해당 기간 동안 발생한 오류 및 예외🎜🎜🎜🎜 🎜🎜 🎜🎜위 내용은 PHP 프로그래머가 직면한 오류 및 예외 1부 오류의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!