本篇文章介紹的內容是PHP程式設計師遇到的錯誤與異常中的錯誤的內容,現在分享給大家,有需要的朋友可以參考一下
PHP錯誤與例外是兩個不同的概念
Depracated最低等級的錯誤(deprecated不建議,不推薦,如舊版的正規
ereg()函數換掉即可,不影響PHP的執行)
#Notice通知層級的錯誤(語法不恰當導致的,不影響PHP的正常運行,如打印一個未定義的變量,所以我們一開始就要養成良好的書寫規範)
Warning警告級別的錯誤(必須修改程式碼)
Fatal error致命等級的錯誤,
#程式會停止
Parse error語法解析錯誤,在程式碼執行前檢查,
將無法執行程式碼
由使用者定義的錯誤,手動拋出錯誤時會用到
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);
錯誤抑制符,放在行首不顯示該行錯誤 手動拋出自訂錯誤訊息:
##
## 錯誤等級:
E_USER_NOTICE # 继续执行(通知级别) E_USER_WARNING # 继续执行(警告错误) E_USER_ERROR # 程序不再执行(致命错误)
#二、處理PHP中的錯誤2.1 將錯誤日誌保存在指定檔案中
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系统错误)
##3.2 自訂錯誤處理器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);
}
}
3.3 錯誤處理器測試
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程式設計師遇到的錯誤與異常上篇之錯誤的詳細內容。更多資訊請關注PHP中文網其他相關文章!