這篇文章主要介紹了PHP 錯誤處理機制的相關資料,十分的詳細,也很實用,需要的朋友可以參考下
在日常的專案開發過程中,總是會出現一些我們意想不到的異常錯誤,如果我們對此沒有進行相對完善的處理,那麼程式看上去也很不專業,也很可能就會成為別人攻擊系統的有效資訊;有些錯誤異常會終止腳本執行,這個時候如果沒有一些錯誤提示訊息的話,那麼我們只能從頭開始看程式碼了,要知道專案中成百上千行的程式碼對我們來說是件多麼恐怖的事情啊,那麼我們如何在專案開發的過程中快速且準確地定位到異常、錯誤呢,並進行相應的處理,本文由自己對錯誤、異常處理的了解,再此分享與大家相互學習交流,並作為一個備忘。
系統錯誤處理器:
PHP正常情況下,錯誤會正常的輸出,但在某些框架中,可能會影響錯誤的輸出,可能是框架本身有自己的處理機制,也可能程式碼中作處理了,一般是這幾個函數設定:
1.error_reporting(); 設定PHP 的報錯等級並傳回目前等級
error_reporting(report_level)
如果參數level 未指定,目前報錯等級將會傳回。以下幾項是level 可能的值:
值 |
||
###########################################################################################################' ###描述##################1#############E_ERROR###########致命的運行時錯誤。不能回收此錯誤。腳本被中斷執行。 ### | ||
2 |
E_WARNING |
非致命的執行時間警告。腳本不被中斷執行。 |
4 |
#E_PARSE |
編譯時分析錯誤。解析應該只由分析器產生的錯誤 |
8 |
#E_NOTICE |
運行時通知。當腳本發現可能是錯誤,但通常在執行一個腳本時,也可能發生 |
16 |
E_CORE_ERROR |
致命錯誤在PHP啟動時。這就好比在PHP核心的E_ERROR |
32 |
E_CORE_WARNING |
在PHP##啟動時警告。這就好比在PHP核心的E_WARNING |
64 | E_COMPILE_ERROR | 致命的編譯時錯誤。這就好比通過了Zend腳本引擎產生的E_ERROR |
##128 | E_COMPILE_WARNING | #非致命編譯時警告。這就好比通過了 Zend#腳本引擎產生E_WARNING |
#E_USER_ERROR | 致命的使用者產生的錯誤,這類似於程式設計師使用PHP | 函數 |
512 |
E_USER_WARNING |
非致命的使用者產生的警告,這類似程式設計師使用PHP函數 trigger_error #設定的 E_WARNING |
##1024 |
E_USER_NOTICE#使用者產生的通知,這類似於程式設計師使用PHP函數 #trigger_error |
|
E_NOTICE | ##2048############ #E_STRICT### | 運行時通知。 PHP建議改變你的程式碼,以幫助程式碼的互通性和相容性 |
4096 |
E_RECOVERABLE_ERROR |
set_error_handler | ()
8191 |
E_ALL所有的錯誤和警告,除級別E_STRICT(在PHP6.0中, E_STRICT將是 ###E_ALL#######的一部分)####### |
這裡值得注意的是,$level為0的時候是關閉錯誤輸出,也就是任何錯誤都不會輸出。
2.set_error_handler()
定義與用法
set_error_handler() 函數設定使用者自訂的錯誤處理函數。
此函數用於建立執行時間期間的使用者自己的錯誤處理方法。
函數會傳回舊的錯誤處理程序,若失敗,則傳回 null。
語法
set_error_handler(error_function,error_types)
參數 |
#描述 |
error_function |
必要。規定發生錯誤時運行的函數。 |
error_types |
#可選。規定在哪個錯誤報告等級會顯示使用者定義的錯誤。預設是 "E_ALL"。 |
提示:如果使用了函數,則會完全繞過標準的PHP 錯誤處理函數,如果必要,使用者定義的錯誤處理程序必須終止(die() ) 腳本,
#註解:如果在腳本執行前發生錯誤,由於在那時自訂程式還沒有註冊,因此就不會用到這個自訂錯誤處理程序。
測試程式碼如下:
/** * * @param type $error_level 错误级别 * @param type $error_message 错误信息 * @param type $error_file 可选 错误文件 * @param type $error_line 可选 错误行 * @param type $error_context 可选。规定一个数组,包含了当错误发生时在用的每个变量以及它们的值。 */ function my_error($error_level, $error_message, $error_file, $error_line, $error_context) { echo date('Y-m-d H:i:s') . $error_level . $error_message . $error_file . $error_line; var_dump($error_context); } set_error_handler('my_error', E_ALL); print_r($a);
//透過上案例可以得知,在註冊my_error 方法時,系統會自動覆寫原有的錯誤處理error_fuction() 方法
以上程序運行結果:
自訂錯誤觸發器
#定義和用法
trigger_error() 函數建立用戶定義的錯誤訊息。
trigger_error() 用於在使用者指定的條件下觸發錯誤訊息。它與內建的錯誤處理器一同使用,也可以與由 set_error_handler() 函數建立的使用者自訂函數使用。
如果指定了一個不合法的錯誤類型,函數會傳回 false,否則傳回 true。
語法
trigger_error(error_message,error_types)
參數 | #描述 |
error_message | 必要。規定錯誤訊息。長度限制為 1024 個字元。 |
error_types | 可选。规定错误消息的错误类型。 可能的值:
|
测试代码如下:
/** * * @param type $level * @param type $msg */ function my_error($level, $msg) { switch ($level) { case E_USER_ERROR: echo "ERROR:<br/>"; break; case E_USER_WARNING: echo "WARNING:<br/>"; break; case E_USER_NOTICE: echo "NOTICE:<br/>"; break; default: break; } echo "错误编号:" . $level . " <br/>"; echo "错误信息:" . $msg; } //注册错误处理器 set_error_handler('my_error'); if (89 > 8) { //调用错误触发器 trigger_error('这是错误啊', E_USER_WARNING); }
运行结果如下:
WARNING:
错误编号:512
错误信息:这是错误啊
以上是php 錯誤處理機制實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!