溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何在PHP中使用error_reporting()函數(shù)

發(fā)布時(shí)間:2021-04-01 16:34:48 來源:億速云 閱讀:179 作者:Leah 欄目:開發(fā)技術(shù)

本篇文章給大家分享的是有關(guān)如何在PHP中使用error_reporting()函數(shù),小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

error_reporting() 函數(shù)規(guī)定報(bào)告哪個(gè)錯(cuò)誤 。該函數(shù)設(shè)置當(dāng)前腳本的錯(cuò)誤報(bào)告級別。該函數(shù)返回舊的錯(cuò)誤報(bào)告級別。

首先要知道error_reporting()函數(shù)是用來設(shè)置錯(cuò)誤級別并返回當(dāng)前級別的。它有14個(gè)錯(cuò)誤級別,如下:

1    E_ERROR     致命的運(yùn)行時(shí)錯(cuò)誤。 錯(cuò)誤無法恢復(fù)過來。腳本的執(zhí)行被暫停
2    E_WARNING    非致命的運(yùn)行時(shí)錯(cuò)誤。 腳本的執(zhí)行不會停止
4    E_PARSE     編譯時(shí)解析錯(cuò)誤。解析錯(cuò)誤應(yīng)該只由分析器生成
8    E_NOTICE     運(yùn)行時(shí)間的通知。
16    E_CORE_ERROR   在PHP啟動時(shí)的致命錯(cuò)誤。這就好比一個(gè)在PHP核心的E_ERROR
32    E_CORE_WARNING  在PHP啟動時(shí)的非致命的錯(cuò)誤。這就好比一個(gè)在PHP核心E_WARNING警告
64    E_COMPILE_ERROR 致命的編譯時(shí)錯(cuò)誤。 這就像由Zend腳本引擎生成了一個(gè)E_ERROR
128   E_COMPILE_WARNING 非致命的編譯時(shí)錯(cuò)誤,由Zend腳本引擎生成了一個(gè)E_WARNING警告
256   E_USER_ERROR   致命的用戶生成的錯(cuò)誤。
512   E_USER_WARNING  非致命的用戶生成的警告。 
1024   E_USER_NOTICE  用戶生成的通知。
2048   E_STRICT     運(yùn)行時(shí)間的通知。

4096   E_RECOVERABLE_ERROR 捕捉致命的錯(cuò)誤。

8191   E_ALL來     所有的錯(cuò)誤和警告。

好像php默認(rèn)是不開啟錯(cuò)誤的,所以你需要配置php.ini文件:

將 display_errors = Off 改為display_errors = On

另外還要配置錯(cuò)誤級別:將

error_reporting = E_ALL     改為:

error_reporting = E_ALL & ~E_NOTICE

應(yīng)為php默認(rèn)是顯示所有錯(cuò)誤的,而有些無害的提示我們不需要顯示,所以設(shè)置如上!

也可以在php代碼運(yùn)用如下:

<?php
//禁用錯(cuò)誤報(bào)告,也就是不顯示錯(cuò)誤
error_reporting(0);
//報(bào)告運(yùn)行時(shí)錯(cuò)誤
error_reporting(E_ERROR | E_WARNING | E_PARSE);
//報(bào)告所有錯(cuò)誤
error_reporting(E_ALL);
?>

使用示例:

今天學(xué)習(xí)CI框架過程中遇到個(gè)問題:

A PHP Error was encountered 
Severity: Notice 

Message: Undefined variable: user

一般在默認(rèn)的普通PHP文件中輸出一個(gè)未定義聲明的變量是不會報(bào)錯(cuò)誤的,但在codeigniter框架下卻要報(bào)錯(cuò)誤,這對于想集成 添加 和 修改 頁面于一體的”懶人”很不方便,由于是初學(xué)者開始還想怎么在代碼中屏蔽這一錯(cuò)誤提示呢.甚至用到了@,但聽很多人都說@會大大降低性能….

最后突然想到,是不是codeigniter有意讓這錯(cuò)誤信息提示出來了呢,我們該如何去屏蔽掉這一類錯(cuò)誤呢?zé)o意中搜索到了”如何讓codeigniter不顯示Notice信息?”,茅塞頓開.原來是入口index.php中的error_reporting(E_ALL);在作怪.只需要把它改成
  error_reporting(E_ALL ^ E_NOTICE);
就可以屏蔽掉這個(gè)錯(cuò)誤,而不影響其他的報(bào)錯(cuò).

我們在程序中可能經(jīng)??吹竭@么一個(gè)函數(shù)

function setErrorReporting()
{
  //從配置文件讀取當(dāng)前是否為開發(fā)環(huán)境
  if (DEV_ENV == true) {
    ini_set("error_reprorting", "E_ALL & ~E_NOTICE");
    ini_set("display_errors", "on");
  } else {
    error_reporting(E_ALL);
    ini_set('display_errors', 'Off');
    ini_set("log_errors" , "On");
    ini_set('error_log', '/var/log/phperror.log');
  }
}

舉例說明:
在Windows環(huán)境下:原本在php4.3.0中運(yùn)行正常的程序,在4.3.1中為何多處報(bào)錯(cuò),大體提示為:Notice:Undefined varialbe:變量名稱.

例如有如下的代碼:
 代碼如下 復(fù)制代碼
if (!$tmp_i) {
$tmp_i=10;
}
在4.3.0中運(yùn)行正常,在4.3.1中運(yùn)行會提示Notice:Undefined varialbe:tmp_i
問題如下:1.問題出在哪里?
2.應(yīng)如何修改這段代碼?
3.不改段代碼,如何修改php.ini中的設(shè)置使原來在4.3.0中的程序在4.3.1的環(huán)境下運(yùn)行正常而不出現(xiàn)這個(gè)錯(cuò)誤提示.
解決辦法:

在程序開頭加一句:
 代碼如下 復(fù)制代碼
error_reporting(E_ALL & ~E_NOTICE); 或error_reporting(E_ALL ^ E_NOTICE);
或者修改php.ini:
 代碼如下 復(fù)制代碼
error_reporting = E_ALL & ~E_NOTICE
有關(guān)error_reporting()函數(shù): error_reporting() 設(shè)置 PHP 的報(bào)錯(cuò)級別并返回當(dāng)前級別。
; 錯(cuò)誤報(bào)告是按位的?;蛘邔?shù)字加起來得到想要的錯(cuò)誤報(bào)告等級。
; E_ALL - 所有的錯(cuò)誤和警告
; E_ERROR - 致命性運(yùn)行時(shí)錯(cuò)
; E_WARNING - 運(yùn)行時(shí)警告(非致命性錯(cuò))
; E_PARSE - 編譯時(shí)解析錯(cuò)誤
; E_NOTICE - 運(yùn)行時(shí)提醒(這些經(jīng)常是是你的代碼的bug引起的,也可能是有意的行為造成的。(如:基于未初始化的變量自動初始化為一個(gè)空字符串的事實(shí)而使用一個(gè)未初始化的變量)
; E_CORE_ERROR - 發(fā)生于PHP啟動時(shí)初始化過程中的致命錯(cuò)誤
; E_CORE_WARNING - 發(fā)生于PHP啟動時(shí)初始化過程中的警告(非致命性錯(cuò))
; E_COMPILE_ERROR - 編譯時(shí)致命性錯(cuò)
; E_COMPILE_WARNING - 編譯時(shí)警告(非致命性錯(cuò))
; E_USER_ERROR - 用戶產(chǎn)生的出錯(cuò)消息
; E_USER_WARNING - 用戶產(chǎn)生的警告消息
; E_USER_NOTICE - 用戶產(chǎn)生的提醒消息
E_NOTICE 表示一般情形不記錄,只有程式有錯(cuò)誤情形時(shí)才用到,例如企圖存取一個(gè)不存在的變數(shù),或是呼叫 stat() 函式檢視不存在的檔案。
E_WARNING 通常都會顯示出來,但不會中斷程式的執(zhí)行。這對除錯(cuò)很有效。例如:用有問題的常規(guī)表示法呼叫 ereg()。
E_ERROR 通常會顯示出來,亦會中斷程式執(zhí)行。意即用這個(gè)遮罩無法追查到記憶體配置或其它的錯(cuò)誤。
E_PARSE 從語法中剖析錯(cuò)誤。
E_CORE_ERROR 類似 E_ERROR,但不包括 PHP 核心造成的錯(cuò)誤。
E_CORE_WARNING 類似 E_WARNING,但不包括 PHP 核心錯(cuò)誤警告

使用方法:
error_reporting(0);//禁用錯(cuò)誤報(bào)告
error_reporting(E_ALL ^ E_NOTICE);//顯示除去 E_NOTICE 之外的所有錯(cuò)誤信息
error_reporting(E_ALL^E_WARNING^E_NOTICE);//顯示除去E_WARNING E_NOTICE 之外的所有錯(cuò)誤信息
error_reporting(E_ERROR | E_WARNING | E_PARSE);//顯示運(yùn)行時(shí)錯(cuò)誤,與error_reporting(E_ALL ^ E_NOTICE);效果相同。error_reporting(E_ALL);//顯示所有錯(cuò)誤
error_reporting(0)
error_reporting(255);
是列出所有提示
error_reporting(0);
是不顯示所有提示
建議使用
error_reporting(7);
只顯示嚴(yán)重錯(cuò)誤
1 E_ERROR 致命的運(yùn)行時(shí)錯(cuò)誤
2 E_WARNING 運(yùn)行時(shí)警告(非致命性錯(cuò)誤)
4 E_PARSE 編譯時(shí)解析錯(cuò)誤
8 E_NOTICE 運(yùn)行時(shí)提醒(經(jīng)常是bug,也可能是有意的)
16 E_CORE_ERROR PHP啟動時(shí)初始化過程中的致命錯(cuò)誤
32 E_CORE_WARNING PHP啟動時(shí)初始化過程中的警告(非致命性錯(cuò))
64 E_COMPILE_ERROR 編譯時(shí)致命性錯(cuò)
128 E_COMPILE_WARNING 編譯時(shí)警告(非致命性錯(cuò))
256 E_USER_ERROR 用戶自定義的致命錯(cuò)誤
512 E_USER_WARNING 用戶自定義的警告(非致命性錯(cuò)誤)
1024 E_USER_NOTICE 用戶自定義的提醒(經(jīng)常是bug,也可能是有意的)
2048 E_STRICT 編碼標(biāo)準(zhǔn)化警告(建議如何修改以向前兼容)
4096 E_RECOVERABLE_ERROR 接近致命的運(yùn)行時(shí)錯(cuò)誤,若未被捕獲則視同E_ERROR
6143 E_ALL 除E_STRICT外的所有錯(cuò)誤(PHP6中為8191,即包含所有)

以上就是如何在PHP中使用error_reporting()函數(shù),小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI