您好,登錄后才能下訂單哦!
這篇文章給大家介紹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 |
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 |
2048 | E_STRICT | 運行時通知。PHP建議改變你的代碼,以幫助該代碼的互操作性和兼容性 |
4096 | E_RECOVERABLE_ERROR | 可捕獲的致命錯誤,類似 E_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項目中是如何對錯誤進行處理的就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。