天天看點

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_WARNING 類似 E_WARNING,但不包括 PHP 核心錯誤警告。

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);