php錯誤處理

高洛峰
發布: 2016-10-08 17:42:47
原創
1309 人瀏覽過

錯誤型別

因為錯誤型別整數值的巧妙設定,可以採用位元運算子

1 E_ERROR (integer)

致命的執行時錯誤。這類錯誤一般是不可恢復的情況,例如記憶體分配所導致的問題。
導致腳本終止不再繼續運行
例子:調用一個未定義的函數,存在沒有捕獲的異常

2 E_WARNING (integer)

運行時警告(非致命錯誤)
僅給出提示信息,但是腳本不會終止運行。

4 E_PARSE (integer)

編譯時語法解析錯誤。
解析錯誤僅由分析器產生。
register_shutdown_function不能捕獲到本文件內發生的這個錯誤

8 E_NOTICE (integer)

運行時通知。表示腳本遇到可能會表現為錯誤的情況,但在可以正常運作的腳本裡面也可能會有類似的通知
例子:使用未定義的變數

16 E_CORE_ERROR (integer)

在PHP初始化啟動過程中發生的致命錯誤。
該錯誤類似 E_ERROR,但是是由PHP引擎核心產生的。

32 E_CORE_WARNING (integer)

PHP初始化啟動過程中發生的警告(非致命錯誤)
類似E_WARNING,但是是由PHP引擎核心產生的

E_COMPILE_egerm

(時錯誤。類似E_ERROR, 但是是由Zend腳本引擎產生的。 since PHP 4
128 E_COMPILE_WARNING (integer)
編譯時警告 (非致命錯誤)。類似 E_WARNING,但是是由Zend腳本引擎產生的。

E_USER_

使用者產生的

256 E_USER_ERROR (integer)

使用者產生的錯誤訊息。類似 E_ERROR, 但是是由使用者自己在程式碼中使用PHP函數 trigger_error()來產生的。 since PHP 4
512 E_USER_WARNING (integer)
使用者產生的警告訊息。類似 E_WARNING, 但是是由使用者自己在程式碼中使用PHP函數 trigger_error()來產生的。 since PHP 4
1024 E_USER_NOTICE (integer)
用戶產生的通知資訊。類似E_NOTICE, 但是是由使用者自己在程式碼中使用PHP函數trigger_error()來產生的

2048 E_STRICT (integer)

啟用PHP 對程式碼的修改建議,以確保程式碼具有最佳的互通性和向前操作相容性.

4096 E_RECOVERABLE_ERROR (integer)

可被捕捉的致命錯誤。 它表示發生了一個可能非常危險的錯誤,但還沒有導致PHP引擎處於不穩定的狀態。 如果該錯誤沒有被使用者自訂句柄捕獲 ( set_error_handler()),將成為一個 E_ERROR 從而腳本會終止執行。

8192 E_DEPRECATED (integer)

運行時通知。
啟用後將會對在未來版本中可能無法正常運作的程式碼給予警告。

16384 E_USER_DEPRECATED (integer)

使用者產生的警告訊息。 類似 E_DEPRECATED, 但是是由使用者自己在程式碼中使用PHP函數 trigger_error()來產生的。

/ 關閉所有PHP錯誤報告,會回傳新的錯誤報告等級error_reporting(0);// Report simple running errorserror_reporting(E_ERROR | E_WARNING | E_PARSE);

如果不帶參數就回傳目前錯誤報告等級

_

取得最後發生的錯誤,register_shutdown_function()常用到

array error_get_last ( void )


回傳結果

Array(

 file] = > C:WWWindex.php    [line] => 2)


trigger_error

產生一個用戶級別的error/warning/notice 資訊

bool trigger_error (string $error_ms,g, pid _log

把錯誤訊息傳送到web 伺服器的錯誤日誌,或到一個檔案裡,檔案不存在時會建立


bool error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] )

message_type

設定錯誤應該發送到何處
0 message 傳送到PHP 的系統日誌,使用作業系統的日誌機製或一個文件,取決於php.ini中error_log 的設定。選項。 。
4 message 直接傳送到SAPI 的日誌處理程序

set_error_handler()

設定一個使用者定義的錯誤處理程序來處理腳本中出現的錯誤

mixed set_error_handler ( callable $error_h [, ] )


error_types 裡指定的錯誤類型都會繞過PHP 標準錯誤處理程序,除非回呼函數回傳了FALSE 。 error_reporting() 設定將不會起到作用而你的錯誤處理函數繼續會被調用,在需要時你有責任使用 die()。

NOTE

以下層級的錯誤不能由使用者定義的函數來處理: E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING,以及在呼叫set_error_handler() 所在檔案中產生的int $errorLevel , string $errorMessage [, string $errfile [, int $errline [, array $errcontext ]]] )

errcontext, 是一個指向錯誤發生時活動符號表的array。 也就是說,errcontext 會包含錯誤觸發處作用域內所有變數的陣列。 使用者的錯誤處理程序不應該修改錯誤上下文(context)。

set_exception_handler


設定一個使用者定義的例外處理函式

getMessage(exceptler"(). ;throw new Exception('Uncaught Exception');echo "Not Executedn";?>


register_shutdown_function

這個函數是在腳本結束之後運行的函數(不管是正常結束還是通過exit、發生錯誤結束)

這個函數是在腳本結束之後運行的函數(不管是正常結束還是通過exit、發生錯誤結束)

php.ini中有關錯誤的配置

php錯誤機制總結

error_reporting = E_ALL  // 报告错误级别,什么级别的error_log = /tmp/php_errors.log // php中的错误显示的日志位置display_errors = On // 是否把错误展示在输出上,这个输出可能是页面,也可能是stdoutdisplay_startup_errors = On // 是否把启动过程的错误信息显示在页面上,记得上面说的有几个Core类型的错误是启动时候发生的,这个就是控制这些错误是否显示页面的。log_errors = On // 是否要记录错误日志log_errors_max_len = 1024 // 错误日志的最大长度ignore_repeated_errors = Off // 是否忽略重复的错误track_errors = Off // 是否使用全局变量$php_errormsg来记录最后一个错误xmlrpc_errors = 0 //是否使用XML-RPC的错误信息格式记录错误xmlrpc_error_number = 0 // 用作 XML-RPC faultCode 元素的值。html_errors = On  // 是否把输出中的函数等信息变为HTML链接docref_root = http://manual/en/ // 如果html_errors开启了,这个链接的根路径是什么fastcgi.logging = 0 // 是否把php错误抛出到fastcgi中

PHP默认是会在日志和标准输出(如果是fpm模式标准输出就是页面)
error_reporting的参数是错误级别。表示什么样子的级别才应该触发错误
display_errors是控制是否要在标准输出展示错误信息
log_errors则是控制是否要在日志中记录错误信息
error_log是显示错误日志的位置

<br/>
登入後複製


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門推薦
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!