摘要:至,有同樣的行為。表示關閉所有錯誤報告表示顯示二函數說明設置應該報告何種錯誤說明函數能夠在運行時設置指令。后果是導致腳本終止不再繼續運行。初始化啟動過程中發生的警告非致命錯誤。用戶產少的警告信息。出外的所有錯誤和警告信息。
錯誤報告級別:指定了在什么情況下,腳本代碼中的錯誤(這里的錯誤是廣義的錯誤,包括E_NOTICE注意、E_WARNING警告、E_ERROR致命錯誤等)會以錯誤報告的形式輸出。一、常用設置說明
error_reporting(-1); 表示顯示所有PHP錯誤報告,包括將來PHP加入的新的錯誤級別。 至PHP5.4,E_ALL有同樣的行為。
error_reporting(0); 表示關閉所有PHP錯誤報告
error_reporting(7); 表示顯示 E_ERROR(1) | E_WARING(2) | E_PARSE(4) == (1+2+4)
二、error_reporting函數說明error_reporting — 設置應該報告何種 PHP 錯誤
說明int error_reporting ([ int $level ] )
error_reporting() 函數能夠在運行時設置 error_reporting 指令。 PHP 有諸多錯誤級別,使用該函數可以設置在腳本運行時的級別。 如果沒有設置可選參數 level, error_reporting() 僅會返回當前的錯誤報告級別。
參數 level新的 error_reporting 級別。 可以是一個位掩碼也可以是一個已命名的常量。 強烈建議使用已命名的常量,以確保兼容將來的版本。 由于錯誤級別的添加、整數取值范圍的增加, 較久的基于整數的錯誤級別不會總是和預期的表現一致。
可用的錯誤級別常量及其實際含義描述在了 predefined constants 中。
值 常量 說明 備注
1 E_ERROR (integer) 致命的運行時錯誤。這類錯誤一般是不可恢復的情況,例如內存分配導致的問題。后果是導致腳本終止不再繼續運行。
2 E_WARNING (integer) 運行時警告 (非致命錯誤)。僅給出提示信息,但是腳本不會終止運行。
4 E_PARSE (integer) 編譯時語法解析錯誤。解析錯誤僅僅由分析器產生。
8 E_NOTICE (integer) 運行時通知。表示腳本遇到可能會表現為錯誤的情況,但是在可以正常運行的腳本里面也可能會有類似的通知。
16 E_CORE_ERROR (integer) 在PHP初始化啟動過程中發生的致命錯誤。該錯誤類似 E_ERROR,但是是由PHP引擎核心產生的。 since PHP 4
32 E_CORE_WARNING (integer) PHP初始化啟動過程中發生的警告 (非致命錯誤) 。類似 E_WARNING,但是是由PHP引擎核心產生的。 since PHP 4
64 E_COMPILE_ERROR (integer) 致命編譯時錯誤。類似E_ERROR, 但是是由Zend腳本引擎產生的。 since PHP 4
128 E_COMPILE_WARNING (integer) 編譯時警告 (非致命錯誤)。類似 E_WARNING,但是是由Zend腳本引擎產生的。 since PHP 4
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()來產生的。 since PHP 4
2048 E_STRICT (integer) 啟用 PHP 對代碼的修改建議,以確保代碼具有最佳的互操作性和向前兼容性。 since PHP 5
4096 E_RECOVERABLE_ERROR (integer) 可被捕捉的致命錯誤。 它表示發生了一個可能非常危險的錯誤,但是還沒有導致PHP引擎處于不穩定的狀態。 如果該錯誤沒有被用戶自定義句柄捕獲 (參見 set_error_handler()),將成為一個 E_ERROR 從而腳本會終止運行。 since PHP 5.2.0
8192 E_DEPRECATED (integer) 運行時通知。啟用后將會對在未來版本中可能無法正常工作的代碼給出警告。 since PHP 5.3.0
16384 E_USER_DEPRECATED (integer) 用戶產少的警告信息。 類似 E_DEPRECATED, 但是是由用戶自己在代碼中使用PHP函數 trigger_error()來產生的。 since PHP 5.3.0
30719 E_ALL (integer) E_STRICT出外的所有錯誤和警告信息。 30719 in PHP 5.3.x, 6143 in PHP 5.2.x, 2047 previously
上面的值(數值或者符號)用于建立一個二進制位掩碼,來制定要報告的錯誤信息。可以使用按位運算符來組合這些值或者屏蔽某些類型的錯誤。請注意,在 php.ini 之中,只有"|", "~", "!", "^" 和 "&" 會正確解析。
如果不關閉E_NOTICE,則未初始化的變量會顯示在頁面:
在php_error_log 中可以看出:
如果給腳本加上這段代碼,就不會爆出這樣的提示:
error_reporting(E_ALL ^ E_NOTICE);三、設置 php.ini
有時候,PHP代碼在調試的時候,有錯誤,不提示是一件很憂傷的事,難道你指望自己猜出問題所在么?當然不行,就算在最頁面最開始執行了 error_reporting(E_ALL),發現還是沒有輸出錯誤,其實原因就是在php.ini里面將display_errors關閉了。可以在php.ini里面將display_errors配置為On,然后重啟php-fpm,如果服務器上既有測試項目,又有線上項目,那么還是不要開啟,以防別人利用你的錯誤,而攻擊你。
只需要再需要測試的項目里面加上即可
ini_set("display_errors","On"); error_reporting(E_ALL);四、在PHP腳本打印錯誤信息
ini_set("display_errors",1); //錯誤信息 ini_set("display_startup_errors",1); //php啟動錯誤信息 error_reporting(-1); //打印出所有的 錯誤信息
項目中打印錯誤信息:
// 錯誤信息 @ini_set("display_errors",1); error_reporting(E_ALL & ~ (E_STRICT | E_NOTICE | E_WARNING));
判斷某個進程是否有運行:
// 判斷程序是否有啟動 define("runcode", 1); $handle = popen("ps -ef | grep redis 2>&1", "r"); $cmd_cont = ""; while(!feof($handle)) { $buffer = fgets($handle); $cmd_cont .= $buffer; } pclose($handle); dump($cmd_cont);
調試腳本:
EOF; echo $str;
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/23209.html
摘要:當程序開發完成,成為正式產品時,我們希望將沒有預測到的報錯信息記錄到錯誤日志中,而不是將這些報錯信息展示給用戶,因為用戶極有可能利用這些暴露出腳本路徑數據庫信息或其他的報錯信息進行一些破壞性的黑客行動。 程序報錯總是在所難免,盡管我們書寫代碼時已經格外小心。 在開發php程序時,我們希望遇到php報錯,可以第一時間展示給我們,以便于調試。當程序開發完成,成為正式產品時,我們希望將沒有預...
摘要:設置時間腳本執行時間設置最大執行內存設置內存獲取使用內存設置與客戶機斷開是否會終止腳本的執行,直至有輸出任務為止設置默認時區與獲取默認時區設置跨域訪問限制跨域文件設置報錯信息開啟報錯,開發環境關閉報錯,生產環境 1.設置時間腳本執行時間 set_time_limit(0); 2.設置最大執行內存 ini_set(memory_limit,1024M);//設置內存 memory_get...
摘要:異常處理上節解讀源碼一自動加載看完了自動加載部分,根據代碼執行順序,的行注冊錯誤和異常處理機制加載慣例配置文件下面的加載配置文件不用說,現在重點看一下異常處理。博客鏈接解讀源碼二異常處理和請求生命周期 異常處理 上節解讀 thinkphp5 源碼(一):自動加載看完了自動加載部分,根據代碼執行順序,base.php的59-64行 // 注冊錯誤和異常處理機制 hinkError::r...
閱讀 3581·2019-08-30 15:55
閱讀 1379·2019-08-29 16:20
閱讀 3662·2019-08-29 12:42
閱讀 2667·2019-08-26 10:35
閱讀 1015·2019-08-26 10:23
閱讀 3411·2019-08-23 18:32
閱讀 902·2019-08-23 18:32
閱讀 2898·2019-08-23 14:55