老鳥有一本《PHP調試手冊》在網路上風行,不管老鳥還是嫩鳥,這篇文章的作用是介紹一些簡單易行的PHP調試實戰技術,希望大家能提出寶貴意見,共同進步。
(一)列印輸出
使用echo/print/print_r/var_dump+exit/die在制定位置輸出調試結果,並終止程式執行。
這招在php的ajax請求中不太好使,如果ajax是get方式的請求,我們可以在瀏覽器中輸入ajax的url來輸出我們的調試資訊,但如果是post方式,改方法就有點力不從心了。
(二)開啟php的錯誤提示功能
1.將php.ini檔案中的display_errors設定為1或On,然後重啟apache使之生效。
2.在php程式中,使用set_ini('display_errors', 'On')函數來動態顯示程式的錯誤資訊。
在程式中動態顯示錯誤的設定必須保證在錯誤發生之前執行,所以最好是把它放在程式入口的地方。
(三)查看apache錯誤記錄檔
1.在linux環境中,可以使用
tail /your/path/to/error_file
來查看apache中發生的最新的錯誤記錄檔。
2.windows下,直接用記事本開啟apache的錯誤記錄檔檔案查看就可以了。
(四)XDebug/ZendDebug
XDebug可以實現遠端偵錯功能,它主要有兩大特色:
1.輸出資訊格式化。
它重寫了系統的var_dump函數,可以讓輸出的資料更加工整、美觀,方便查看。唯一的缺點是,當顯示的資料量很大的時候,它會隱藏未能現實的部分。
2.遠端偵錯功能。
XDebug工作過程主要由兩部分組成:Xdebug Server, Xdebug Client。看上去,它有點像寄生在apache中的後門程式。它的工作原理如下,
XDebug Client-----------(帶xdebug session資訊的遠程頁面請求)----------->XDebug Server(可以配置響應請求的主機和連接埠)
XDebug Client<---------(串連資訊確認,並返回請求頁面資料)------------------XDebug Server
XDebug Client-----------(發送breakpoint、AddWatch等調試命令)---------->XDebug Server
XDebug Client<---------(接收Server返回的PHP執行狀態資訊)------------------XDebug Server
......
XDebug Client-----------(帶xdebug session資訊的遠程頁面請求終止)-------->XDebug Server(中斷連線)
在PHPEclipse中使用XDebug:
1.安裝XDebug擴充,詳細步驟請參考其他網路資源。
2.在PHPEclipse中設定XDebug
(1)指定使用XDebug調試器
(2)指定PHP的可執行檔路徑
(3)設定遠程主機及連接埠
(4)佈建要求網站和用於調試的瀏覽器
(5)按F11開始調試吧。
本文尚不完整,等有時間了再進行進一步的整理。
本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/wirror800/archive/2010/10/30/5975653.aspx