(1)使用echo ,簡(jiǎn)單輸出
成都創(chuàng)新互聯(lián)專注于企業(yè)網(wǎng)絡(luò)營(yíng)銷推廣、網(wǎng)站重做改版、弋江網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5網(wǎng)站設(shè)計(jì)、商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為弋江等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
(2)使用print_r(),可以有規(guī)則的打印復(fù)雜結(jié)構(gòu)
(3)var_dump遞歸輸出某種結(jié)構(gòu)體
(4)print(),簡(jiǎn)單打印
可以將你要輸出的錯(cuò)誤內(nèi)容放到上述語句或函數(shù)內(nèi)進(jìn)行打印輸出;也可以寫入某個(gè)文件,作為你的Log日志:file_put_contents('/test1.txt',$value['value'],FILE_APPEND)等這類文件函數(shù)
以上是我自己工作中總結(jié)的PHP調(diào)試方法,挺好用的。
display_errors
錯(cuò)誤回顯,一般常用語開發(fā)模式,但是很多應(yīng)用在正式環(huán)境中也忘記了關(guān)閉此選項(xiàng)。錯(cuò)誤回顯可以暴露出非常多的敏感信息,為攻擊者下一步攻擊提供便利。推薦關(guān)閉此選項(xiàng)。
display_errors
=
On
開啟狀態(tài)下,若出現(xiàn)錯(cuò)誤,則報(bào)錯(cuò),出現(xiàn)錯(cuò)誤提示
dispaly_errors
=
Off
關(guān)閉狀態(tài)下,若出現(xiàn)錯(cuò)誤,則提示:服務(wù)器錯(cuò)誤。但是不會(huì)出現(xiàn)錯(cuò)誤提示
log_errors
在正式環(huán)境下用這個(gè)就行了,把錯(cuò)誤信息記錄在日志里。正好可以關(guān)閉錯(cuò)誤回顯。
對(duì)于PHP開發(fā)人員來說,一旦某個(gè)產(chǎn)品投入使用,那么第一件事就是應(yīng)該將display_errors選項(xiàng)關(guān)閉,以免因?yàn)檫@些錯(cuò)誤所透露的路徑、數(shù)據(jù)庫(kù)連接、數(shù)據(jù)表等信息而遭到黑客攻擊。
某個(gè)產(chǎn)品投入使用后,難免會(huì)有錯(cuò)誤信息,那么如何記錄這些對(duì)開發(fā)人員非常有用的信息呢?
將PHP的log_errors開啟即可,默認(rèn)是記錄到WEB服務(wù)器的日志文件里,比如Apache的error.log文件。
當(dāng)然也可以記錄錯(cuò)誤日志到指定的文件中。
復(fù)制代碼
代碼如下:
#
vim
/etc/php.inidisplay_errors
=
Off
log_errors
=
On
error_log
=
/var/log/php-error.log
另外也可以設(shè)定error_log
=
syslog,使這些錯(cuò)誤信息記錄到操作系統(tǒng)的日志里。
display_errors
=
Off
//display中文意思是顯示所以display_error=off的意思就是不顯示錯(cuò)誤了!
error_reporting
設(shè)定錯(cuò)誤訊息回報(bào)的等級(jí)
2047我記得應(yīng)該是E_ALL。
php.ini
文件中有許多配置設(shè)置。您應(yīng)當(dāng)已經(jīng)設(shè)置好自己的
php.ini
文件并把它放在合適的目錄中,就像在
Linux
上安裝
PHP
和
Apache
2
的文檔說明中所示的那樣(請(qǐng)參閱
參考資料)。在調(diào)試
PHP
應(yīng)用程序時(shí),應(yīng)當(dāng)知道兩個(gè)配置變量。下面是這兩個(gè)變量及其默認(rèn)值:
display_errors
=
Off
//關(guān)閉所有錯(cuò)誤信息,為ON時(shí)為顯示所有錯(cuò)誤信息。
error_reporting
=
E_ALL
E_ALL能從不良編碼實(shí)踐到無害提示到出錯(cuò)的所有信息。E_ALL
對(duì)于開發(fā)過程來說有點(diǎn)太細(xì),因?yàn)樗谄聊簧蠟橐恍┬∈拢ɡ缱兞课闯跏蓟┮诧@示提示,會(huì)搞糟瀏覽器的輸出
所以不建議使用2047,最好把默認(rèn)值改為:error_reporting
=
E_ALL
~E_NOTICE
PHP.ini中display_errors
=
Off失效的解決
問題:
PHP設(shè)置文件php.ini中明明已經(jīng)設(shè)置display_errors
=
Off,但是在運(yùn)行過程中,網(wǎng)頁上還是會(huì)出現(xiàn)錯(cuò)誤信息。
解決:
經(jīng)查log_errors=
On,據(jù)官方的說法,當(dāng)這個(gè)log_errors設(shè)置為On,那么必須指定error_log文件,如果沒指定或者指定的文件沒有權(quán)限寫入,那么照樣會(huì)輸出到正常的輸出渠道,那么也就使得display_errors
這個(gè)指定的Off失效,錯(cuò)誤信息還是打印了出來。于是將log_errors
=
Off,問題就解決了。
經(jīng)常見到error_reporting(7)直意為:設(shè)定錯(cuò)誤訊息回報(bào)的等級(jí)。
value
constant
1
E_ERROR
2
E_WARNING
4
E_PARSE
8
E_NOTICE
16
E_CORE_ERROR
32
E_CORE_WARNING
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
然而7=1+2+4
就是出錯(cuò)時(shí)顯示1
E_ERROR
2
E_WARNING
4
E_PARSE
復(fù)制代碼
代碼如下:
?php
//禁用錯(cuò)誤報(bào)告
error_reporting(0);
//報(bào)告運(yùn)行時(shí)錯(cuò)誤
error_reporting(E_ERROR
|
E_WARNING
|
E_PARSE);
//報(bào)告所有錯(cuò)誤
error_reporting(E_ALL);
?
第一:錯(cuò)誤日志自己做,一般不會(huì)自動(dòng)產(chǎn)生。
第二:錯(cuò)誤日志一般在文本文件末尾添加,文件不會(huì)被瀏覽器加載,不影響打開,但如果錯(cuò)誤較多,用戶也多,寫文件會(huì)較慢,一般情況影響不大。
第三:不是,可用isset查看是否定義該數(shù)據(jù)。
500錯(cuò)誤首先就需要先開啟php錯(cuò)誤日志,通過php錯(cuò)誤日志來排錯(cuò)。
LNMP下的錯(cuò)誤需要編輯 /usr/local/php/etc/php-fpm.conf 加上
php_admin_value[error_log] = /usr/local/php/var/log/php_errors.log
php_admin_flag[log_errors] = on
或在/usr/local/php/etc/php-fpm.conf里設(shè)置,加上catch_workers_output
= yes,錯(cuò)誤信息就會(huì)記錄到php-fpm.conf里error_log設(shè)置的文件里。 上述兩種方法都行,重啟php-fpm生效
同理php.ini里的display_errors也是需要在php-fpm.conf里設(shè)置的,加上php_flag[display_errors]
= On就開啟了。 有時(shí)可能錯(cuò)誤日志文件不自動(dòng)創(chuàng)建,可以執(zhí)行:touch
/usr/local/php/var/log/php_errors.log