php error_reporting()關閉報錯


錯誤報告級別:指定了在什么情況下,腳本代碼中的錯誤(這里的錯誤是廣義的錯誤,包括 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,則未初始化的變量會顯示在頁面:

clipboard.png

在php_error_log 中可以看出:

clipboard.png

如果給腳本加上這段代碼,就不會爆出這樣的提示:

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM