錯誤報告級別:指定了在什么情況下,腳本代碼中的錯誤(這里的錯誤是廣義的錯誤,包括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 之中,只有'|', '~', '!', '^' 和 '&' 會正確解析。
<?php // 關閉所有PHP錯誤報告 error_reporting(0); // 報告簡單的運行錯誤 error_reporting(E_ERROR | E_WARNING | E_PARSE); error_reporting(7); // 報告 E_NOTICE 也挺好 (報告未初始化的變量或者捕獲變量名的錯誤拼寫) error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE); // 除了 E_NOTICE,報告其他所有錯誤 // 這是在 php.ini 里的默認設置 error_reporting(E_ALL ^ E_NOTICE); // 報告所有 PHP 錯誤 (參見 changelog) error_reporting(E_ALL); // 報告所有 PHP 錯誤 error_reporting(-1); // 和 error_reporting(E_ALL); 一樣 ini_set('error_reporting', E_ALL); ?>
如果不關閉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);
調試腳本:
<?php /** * --------------------------------- * 調試系統-在線編輯器 * --------------------------------- * @desc 如需使用該在線編輯器,則需要設置常量:define('run', 1); * @author Corwien * @version 2017-07 * --------------------------------- */ // 加載配置文件 define('IN_EB', true); define('ROOT_PATH', __DIR__ . "/"); // 錯誤信息 @ini_set('display_errors', 1); error_reporting(E_ALL & ~ (E_STRICT | E_NOTICE | E_WARNING)); // 初始化 $text = isset($_REQUEST['text']) ? $_REQUEST['text'] : ''; preg_match("/define\('run', 1\);/", $text) && eval($text); // if($text == '') $text = "define('runcode', 1);";
轉載:https://segmentfault.com/a/1190000010113821