錯誤型別
因為錯誤型別整數值的巧妙設定,可以採用位元運算子
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)
bool error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] )
設定錯誤應該發送到何處
0 message 傳送到PHP 的系統日誌,使用作業系統的日誌機製或一個文件,取決於php.ini中error_log 的設定。選項。 。
4 message 直接傳送到SAPI 的日誌處理程序
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)。
設定一個使用者定義的例外處理函式
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/>