php錯(cuò)誤級(jí)別的設(shè)置方法
更新時(shí)間:2013年06月17日 09:53:32 作者:
PHP在運(yùn)行時(shí), 針對(duì)嚴(yán)重程度不同的錯(cuò)誤,會(huì)給以不同的提示,這里簡(jiǎn)單介紹下, 方便需要的朋友
PHP在運(yùn)行時(shí), 針對(duì)嚴(yán)重程度不同的錯(cuò)誤,會(huì)給以不同的提示。
eg:在$a沒(méi)聲明時(shí),直接相加,值為NULL,相加時(shí)當(dāng)成0來(lái)算.但是,卻提示NOTICE,即注意.
我們?cè)陂_發(fā)中, 為了程序的規(guī)范性,把報(bào)錯(cuò)級(jí)別,調(diào)的比較高NOTICE級(jí)別的也報(bào)出來(lái),有助于我們快速定位錯(cuò)誤和代碼規(guī)范,但是,在產(chǎn)品上線后,網(wǎng)站運(yùn)營(yíng)過(guò)程中,就不宜報(bào)這么多錯(cuò).
1:這種錯(cuò)誤給客戶的印象不好
2:在報(bào)錯(cuò)時(shí),把網(wǎng)站的絕對(duì)路徑,如D:\www\1015都報(bào)出來(lái)了.增大被攻擊的風(fēng)險(xiǎn)
因此,在網(wǎng)站上線后,就應(yīng)該讓報(bào)錯(cuò)級(jí)降低,少報(bào)錯(cuò)甚至不報(bào).
修改報(bào)錯(cuò)級(jí)別:
1: php.ini里修改error_reporting 選項(xiàng)
2: 可以在php頁(yè)面里,用error_reporting()函數(shù)來(lái)修改
錯(cuò)誤級(jí)別用2進(jìn)制的值來(lái)表示的: 1111 1111 1111 111從左到右,每位上的1,代表一種錯(cuò)誤級(jí)別
fatal error致命錯(cuò)誤: 0000 0000 0000 001 開啟 1
warning 警告錯(cuò)誤 : 0000 0000 0000 010 開啟 2
NOTICE 警告 : 0000 0000 0001 000 開啟 8
eg:
都報(bào)出來(lái): error_reporting(11);
不要報(bào)NOTICE: error_reporting(3);
任何錯(cuò)誤都不報(bào): error_reporting(0);
系統(tǒng)為我們把各個(gè)級(jí)別的值,用系統(tǒng)常量代替了.
E_ERROR 1
E_WARNING 2
E_NOTICE 8
報(bào)所有錯(cuò)誤: error_reporting(E_ALL);
除了NOTICE,其他都報(bào): error_reporting(E_ALL & ~E_NOTICE);
在開發(fā)中,報(bào)錯(cuò)級(jí)別高一點(diǎn),在上線產(chǎn)品中,報(bào)錯(cuò)級(jí)別要低:+
define('DEBUG',true); // 在開發(fā)時(shí),聲明一個(gè)DEBUG模式
if(defined('DEBUG')) { //檢測(cè)到處于開發(fā)模式
error_reporting(E_ALL);
} else {
error_reporting(0);
}
eg:在$a沒(méi)聲明時(shí),直接相加,值為NULL,相加時(shí)當(dāng)成0來(lái)算.但是,卻提示NOTICE,即注意.
我們?cè)陂_發(fā)中, 為了程序的規(guī)范性,把報(bào)錯(cuò)級(jí)別,調(diào)的比較高NOTICE級(jí)別的也報(bào)出來(lái),有助于我們快速定位錯(cuò)誤和代碼規(guī)范,但是,在產(chǎn)品上線后,網(wǎng)站運(yùn)營(yíng)過(guò)程中,就不宜報(bào)這么多錯(cuò).
1:這種錯(cuò)誤給客戶的印象不好
2:在報(bào)錯(cuò)時(shí),把網(wǎng)站的絕對(duì)路徑,如D:\www\1015都報(bào)出來(lái)了.增大被攻擊的風(fēng)險(xiǎn)
因此,在網(wǎng)站上線后,就應(yīng)該讓報(bào)錯(cuò)級(jí)降低,少報(bào)錯(cuò)甚至不報(bào).
修改報(bào)錯(cuò)級(jí)別:
1: php.ini里修改error_reporting 選項(xiàng)
2: 可以在php頁(yè)面里,用error_reporting()函數(shù)來(lái)修改
錯(cuò)誤級(jí)別用2進(jìn)制的值來(lái)表示的: 1111 1111 1111 111從左到右,每位上的1,代表一種錯(cuò)誤級(jí)別
fatal error致命錯(cuò)誤: 0000 0000 0000 001 開啟 1
warning 警告錯(cuò)誤 : 0000 0000 0000 010 開啟 2
NOTICE 警告 : 0000 0000 0001 000 開啟 8
eg:
都報(bào)出來(lái): error_reporting(11);
不要報(bào)NOTICE: error_reporting(3);
任何錯(cuò)誤都不報(bào): error_reporting(0);
系統(tǒng)為我們把各個(gè)級(jí)別的值,用系統(tǒng)常量代替了.
E_ERROR 1
E_WARNING 2
E_NOTICE 8
報(bào)所有錯(cuò)誤: error_reporting(E_ALL);
除了NOTICE,其他都報(bào): error_reporting(E_ALL & ~E_NOTICE);
在開發(fā)中,報(bào)錯(cuò)級(jí)別高一點(diǎn),在上線產(chǎn)品中,報(bào)錯(cuò)級(jí)別要低:+
復(fù)制代碼 代碼如下:
define('DEBUG',true); // 在開發(fā)時(shí),聲明一個(gè)DEBUG模式
if(defined('DEBUG')) { //檢測(cè)到處于開發(fā)模式
error_reporting(E_ALL);
} else {
error_reporting(0);
}
相關(guān)文章
讓Nginx支持ThinkPHP的URL重寫和PATHINFO的方法分享
ThinkPHP支持通過(guò)PATHINFO和URL rewrite的方式來(lái)提供友好的URL,只需要在配置文件中設(shè)置 'URL_MODEL' => 2 即可。在Apache下只需要開啟mod_rewrite模塊就可以正常訪問(wèn)了,但是Nginx中默認(rèn)是不支持PATHINFO的,所以我們需要修改nginx.conf文件。2011-08-08
php實(shí)現(xiàn)三級(jí)級(jí)聯(lián)下拉框
這篇文章主要介紹了php實(shí)現(xiàn)三級(jí)級(jí)聯(lián)下拉框,上網(wǎng)翻找了許多三級(jí)級(jí)聯(lián)下拉框?qū)崿F(xiàn)的資料,下面分享給大家2016-04-04
php 多進(jìn)程編程父進(jìn)程的阻塞與非阻塞實(shí)例分析
這篇文章主要介紹了php 多進(jìn)程編程父進(jìn)程的阻塞與非阻塞,結(jié)合實(shí)例形式分析了php 多進(jìn)程編程中父進(jìn)程的阻塞、等待、子進(jìn)程退出、非阻塞等相關(guān)操作技巧,需要的朋友可以參考下2020-02-02
php不使用copy()函數(shù)復(fù)制文件的方法
這篇文章主要介紹了php不使用copy()函數(shù)復(fù)制文件的方法,涉及php讀寫文件的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
淺析Mysql 數(shù)據(jù)回滾錯(cuò)誤的解決方法
以下小編為大家介紹一下關(guān)于Mysql數(shù)據(jù)回滾錯(cuò)誤的解決方法。需要的朋友可以過(guò)來(lái)參考下2013-08-08

