首頁 > 後端開發 > php教程 > crystal report PHP中error_reporting函數的用法修改PHP屏蔽錯誤

crystal report PHP中error_reporting函數的用法修改PHP屏蔽錯誤

WBOY
發布: 2016-07-29 08:45:55
原創
1199 人瀏覽過

今天學習CI框架過程中遇到個問題:
A PHP Error was encountered
Severity: Notice
Message: Undefined variable: user
一般在預設的普通PHP檔案中輸出一個未定義聲明的變數是不會報錯誤的,但在codeigniter框架下卻要報錯誤,這對於想集成添加和修改頁面於一體的」懶人」很不方便,由於是初學者開始還想怎麼在程式碼中屏蔽這錯誤提示呢.甚至用到了@,但聽很多人都說@會大大降低性能….
最後突然想到,是不是codeigniter有意讓這錯誤信息提示出來了呢,我們該如何去屏蔽掉這一類錯誤呢無意中搜索到了”如何讓codeigniter不顯示Notice信息?”,茅塞頓開.原來是入口index.php中的error_reporting(E_ALL);在作怪.只需要把它改成
  error_reporting(E_ALL ^ E_NOTICE);
就可以屏蔽掉這個錯誤,而不影響其他的報錯.
下邊是搜尋到的一些資料:
error_reporting() 設定PHP 的報錯層級並返回目前層級。
語法
error_reporting(report_level)
如果參數 level 未指定,則目前報錯等級將會傳回。下列幾項是level 可能的值:
1 E_ERROR
2 E_WARNING
4 E_PARSE
8 E_NOTICE
16 E_CORE_ERROR
32 E_CORE_N16E_CORE_ERROR
32 E_CORE_N. NING
256 E_USER_ERROR
512 E_USER_WARNING
1024 E_USER_NOTICE
2047 E_ALL
2048 E_STRICT
2047 E_ALL
2048 E_STRICT
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 時,應該已經接觸過 /conf/httpd.conf 中 http.conf 檔案中的基本設定。
  要做在php.ini檔案中已經做過的事,請把下列各行加到httpd.conf,覆寫任何php.ini 檔案:
    php_flag display_errors on
   php_flag display_errors on
   n orreportn.會覆蓋在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(ICT')); if ($old_error_reporting & E_STRICT) {
error_reporting($old_error_reporting ^ E_STRICT);
} else {
error_reporting($old_error_reporting);


常見的如下:



複製程式碼

程式碼如下:// Turnoff all error reporting;關閉所有的錯誤

error_reporting(0);

// Report simple running errors;報告一個簡單的運行錯誤
error_reporting(E_ERROR | E_WARNING | E_PARSE);
// Reporting Ebe too (to report uninitialized
// variables or catch variable name misspellings …);包括報告一些未初始化的變數或捕捉變數名稱的拼字錯誤
error_reporting(E_ERROR | E_WARNING | E_PARPARSE E_NOTICE); // Report all errors except E_NOTICE
// This is the default value set in php.ini;回報所有的錯誤但不包括E_NOTICE 這也是php.ini的預設設定
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); 'error_reporting', E_ALL);


以上就介紹了crystal report PHP中error_reporting函數的用法修改PHP屏蔽錯誤,包括了crystal report方面的內容,希望對PHP教程有興趣的朋友有所幫助。


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板