php error_reporting()關閉報錯

錯誤報告級別:指定了在什麼狀況下,腳本代碼中的錯誤(這裏的錯誤是廣義的錯誤,包括 E_NOTICE注意、 E_WARNING警告、 E_ERROR致命錯誤等)會以錯誤報告的形式輸出。

1、經常使用設置說明

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)

2、error_reporting函數說明

error_reporting — 設置應該報告何種 PHP 錯誤php

說明

int error_reporting ([ int $level ] )

error_reporting() 函數可以在運行時設置 error_reporting 指令。 PHP 有諸多錯誤級別,使用該函數能夠設置在腳本運行時的級別。 若是沒有設置可選參數 level, error_reporting() 僅會返回當前的錯誤報告級別。redis

參數 level

新的 error_reporting 級別。 能夠是一個位掩碼也能夠是一個已命名的常量。 強烈建議使用已命名的常量,以確保兼容未來的版本。 因爲錯誤級別的添加、整數取值範圍的增長, 較久的基於整數的錯誤級別不會老是和預期的表現一致。
可用的錯誤級別常量及其實際含義描述在了 predefined constants 中。segmentfault

值 常量 說明 備註
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 previouslybash

上面的值(數值或者符號)用於創建一個二進制位掩碼,來制定要報告的錯誤信息。可使用按位運算符來組合這些值或者屏蔽某些類型的錯誤。請注意,在 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

若是給腳本加上這段代碼,就不會爆出這樣的提示:php-fpm

error_reporting(E_ALL ^ E_NOTICE);

3、設置 php.ini

有時候,PHP代碼在調試的時候,有錯誤,不提示是一件很憂傷的事,難道你期望本身猜出問題所在麼?固然不行,就算在最頁面最開始執行了 error_reporting(E_ALL),發現仍是沒有輸出錯誤,其實緣由就是在php.ini裏面將display_errors關閉了。能夠在php.ini裏面將display_errors配置爲On,而後重啓php-fpm若是服務器上既有測試項目,又有線上項目,那麼仍是不要開啓,以防別人利用你的錯誤,而攻擊你測試

只須要再須要測試的項目裏面加上便可spa

ini_set('display_errors','On'); error_reporting(E_ALL);

4、在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
相關文章
相關標籤/搜索