php的報錯級別

在php.ini中可以設置服務器對錯誤的報警級別。在默認情況下,php將報告除了通知之外的所有錯誤。
錯誤報告級別是通過一些預定義的常量來設置的,

語法
int error_reporting ( [int level] )
如果參數 level 未指定,當前報錯級別將被返回。下面幾項是 level 可能的值:
如下表所示:
1        E_ERROR        報告運行時的致命錯誤
2        E_WARNING        報告運行的非致命錯誤

4        E_PARSE        報告解析錯誤
8        E_NOTICE        報告通告,注意,表示所做的事情可能是錯誤的.
16           E_CORE_ERROR        報告PHP引擎啓動失敗
32           E_CORE_WARNING    報告PHP引擎啓動時非致命錯誤

64           E_COMPILE_ERROR    報告編譯錯誤
128         E_COMPILE_WARNING    報告編譯時出現的非致命錯誤

256         E_USER_ERROR        報告用戶觸發的錯誤
512         E_USER_WARNING    報告用戶觸發的警告

1024          E_USER_NOTICE        報告用戶觸發的通告
2047       E_ALL            報告所有的錯誤和警告
2048       E_STRICT        報告不贊成的用法和不推薦的行爲

在php.ini文件中,默認的報告是除了通知之外的所有錯誤,如下語句設定:
    error_reporting = E_ALL & ~ (E_NOTICE)
在上面的表達式中,符號"&"表示幾個條件這間的並列,而"~"表示否定,即NOT的含義.
如果想忽略警告信息,可以設定如下語句:
    error_reporting = E_ALL & ~(E_NOTICE) & ~(E_WARNING)
在php.ini文件中,和錯誤有關的設置有如下幾個:
(1)error_reporting,設定錯誤級別
(2)display_errors,是否顯示錯誤報告,設置爲ON則打開,設置爲OFF則關閉所有錯誤提示
(3)log_errors,默認設置爲OFF,是否記錄錯誤日誌;
(4)track_errors,默認設置爲OFF,該選項可以幫助解決代碼中的錯誤,而不是讓PHP提供其默認的功能。


網上搜集:
E_NOTICE 表示一般情形不記錄,只有程式有錯誤情形時纔用到,例如企圖存取一個不存在的變數,或是呼叫 stat() 函式檢視不存在的檔案。


E_WARNING 通常都會顯示出來,但不會中斷程式的執行。這對除錯很有效。例如:用有問題的常規表示法呼叫 ereg()。
E_ERROR 通常會顯示出來,亦會中斷程式執行。意即用這個遮罩無法追查到記憶體配置或其它的錯誤。
E_PARSE 從語法中剖析錯誤。
E_CORE_ERROR 類似 E_ERROR,但不包括 PHP 核心造成的錯誤。
E_CORE_WARNING 類似 E_WARNING,但不包括 PHP 核心錯誤警告。
PHP 的錯誤報告
  php.ini 文件中有許多配置設置。您應當已經設置好自己的 php.ini 文件並把它放在合適的目錄中,就像在 Linux 上安裝 PHP 和 Apache 2 的文檔說明中所示的那樣。在調試 PHP 應用程序時,應當知道兩個配置變量。下面是這兩個變量及其默認值:
display_errors = Off
error_reporting = E_ALL
  通過在 php.ini 文件中搜索它們,可以發現這兩個變量當前的默認值。display_errors 變量的目的很明顯 —— 它告訴 PHP 是否顯示錯誤。默認值是 Off。但是,要讓開發過程更加輕鬆,請把這個值設爲 On:
display_errors = On
  error_reporting 變量的默認值是 E_ALL。這個設置會顯示從不良編碼實踐到無害提示到出錯的所有信息。E_ALL 對於開發過程來說有點太細,因爲它在屏幕上爲一些小事(例如變量未初始化)也顯示提示,會搞糟瀏覽器的輸出。我只想看到錯誤和不良編碼實踐,但是不想看到 無害的提示。所以,請用以下值代替 error_reporting 的默認值:
error_reporting = E_ALL & ~E_NOTICE
  重新啓動 Apache,就全部設置好了。接下來,將學習如何在 Apache 上做同樣的事。
  服務器上的錯誤報告
  依賴於 Apache 正在做的工作,在 PHP 中打開錯誤報告可能沒法工作,因爲在計算機上可能有多個 PHP 版本。有時很難區分 Apache 正在使用哪個 PHP 版本,因爲 Apache 只能查看一個 php.ini 文件。不知道 Apache 正在使用哪個 php.ini 文件配置自己是一個安全問題。但是,有一種方法可以在 Apache 中配置 PHP 變量,從而保證設置了正確的出錯級別。
  而且,最好知道如何在服務器端設置這些配置變量,以否決或搶佔 php.ini 文件,從而提供更高級別的安全性。
在配置 Apache 時,應該已經接觸過 <apache2-install-dir>/conf/httpd.conf 中 http.conf 文件中的基本配置。
  要做在 php.ini 文件中已經做過的事,請把下列各行添加到 httpd.conf,覆蓋任何 php.ini 文件:
php_flag   display_errors         on
php_value error_reporting       2039
  這會覆蓋在 php.ini 文件中爲 display_errors 已經設置的標誌,以及 error_reporting 的值。值 2039 代表 E_ALL & ~E_NOTICE。如果願意採用 E_ALL,請把值設爲 2047。同樣,還是要重啓 Apache。
  接下來,要在服務器上測試錯誤報告。

關於error_reporting()這個函數,它是可以屏蔽到一些錯誤信息,但是PHP 核心造成的錯誤,是無法屏蔽的,因爲PHP 核心造成的錯誤會直接導致PHP文件編譯失敗,因爲書寫格式沒有按照PHP的編碼規則寫而造成的錯誤,是無法屏蔽的

* For now, avoid warnings of E_STRICT mode
* (this must be done before function definitions)
*/
if (defined(’E_STRICT’)) {
    $old_error_reporting = error_reporting(0);
    if ($old_error_reporting & E_STRICT) {
        error_reporting($old_error_reporting ^ E_STRICT);
    } else {
        error_reporting($old_error_reporting);
    }
    unset($old_error_reporting);

常見的如下:

// Turn off all error reporting;關閉所有的錯誤
error_reporting(0);
// Report simple running errors;報告一個簡單的運行錯誤
error_reporting(E_ERROR | E_WARNING | E_PARSE);
// Reporting E_NOTICE can be good too (to report uninitialized
// variables or catch variable name misspellings …);包括報告一些未初始化的變量或捕捉變量名的拼寫錯誤
error_reporting(E_ERROR | E_WARNING | E_PARSE | E_NOTICE);
// Report all errors except E_NOTICE
// This is the default value set in php.ini;報告所有的錯誤但不包括E_NOTICE
error_reporting(E_ALL ^ E_NOTICE);
// Report all PHP errors (bitwise 63 may be used in PHP 3);報告所有的錯誤
error_reporting(E_ALL);
// Same as error_reporting(E_ALL);同上
ini_set(’error_reporting’, E_ALL);

發佈了31 篇原創文章 · 獲贊 23 · 訪問量 50萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章