PHP中的debug(偵錯)方法有:1、在PHP程式碼中新增echo、var_dump、print_r和exit語句,通過瀏覽器列印資訊進行偵錯;2、使用Xdebug進行偵錯;3、通過console終端進行偵錯。
本教學操作環境:windows7系統、PHP7.1版、DELL G3電腦
通過瀏覽器列印資訊進行偵錯
方法
在程式碼中新增 echo、var_dump、print_r 和 exit,在瀏覽器中檢視輸出。
優缺點
優點:
缺點:
技巧
偵錯時,為了格式化輸出變數,往往需要在專案中實現自己的 dump()
函數。利用 Composer,可以全域性安裝 symfony/var-dumper
包中的 dump()
函數,使所有專案都可以使用,而無需改動專案。
symfony/var-dumper
包: ${HOME}/.config/composer
目錄composer global require symfony/var-dumper
php.ini
檔案,執行 PHP 程式碼之前先 include 指定的檔案auto_prepend_file = ${HOME}/.config/composer/vendor/autoload.php
使用 Xdebug 進行偵錯
XDebug 是 C/S 結構,其中 Client 是 PHP 中安裝的 Xdebug,Server 是 IDE 中安裝的外掛,使用 DBGP 協定通訊。PHP 執行指令碼時,通過 Xdebug 外掛向 IDE 傳送偵錯資訊,並接收 IDE 發過來的控制訊號。
需要為 PHP 安裝並開啟 Xdebug,然後設定 IDE 的 Xdebug 外掛,使二者可以通訊。
優缺點
XDEBUG_SESSION_START
引數Web App 偵錯
對於 web 應用,要開啟 Xdebug 偵錯模式,必須在瀏覽器傳送的請求中新增額外的標誌。可以在 GET/POST/Cookie 引數中新增 XDEBUG_SESSION_START=session_name
,這樣 Xdebug 就明白這個請求需要偵錯,去連線 IDE。
但每次手工設定也很麻煩,有兩種方式簡化操作:
XDEBUG_SESSION_START=session_name
。通過 console 終端進行偵錯(CLI 方式)
對於非 web 應用,例如定時任務或單元測試,可以直接在控制檯進行偵錯。
PhpStorm 中通過 Alt+F12
快捷鍵開啟命令列終端。但是因為 IDE 中只能顯示一個終端,在開啟偵錯後的偵錯終端會覆蓋命令列終端,所以還是單獨開一個命令列終端吧(Windows 下可以使用 DOS 視窗或 PowerShell)。
方法及原理
web 應用通過 GET/POST/Cookie 引數標誌偵錯請求,而非 web 應用則通過在命令列終端設定環境變數來開啟偵錯。
兩步:
XDEBUG_CONFIG="idekey=session_name"
,這個 idekey 需要跟 php.ini
中 Xdebug 部分設定的 idekey 一樣。IDE通常提供快捷操作,對於 PHPStorm 可以參考 Debugging PHP CLI scripts with PhpStorm。
通過 IDE 啟動偵錯後,IDE 會啟動 Xdebug 外掛監聽某個埠(PhpStorm 預設是 9000,但是這跟 PHP-FPM 衝突了,可以改為 9001),獲取 PHP 伺服器返回的偵錯資訊。
D:\lnmp\php72\php.exe -dxdebug.remote_enable=1 -dxdebug.remote_mode=req -dxdebug.remote_port=9001 -dxdebug.remote_host=127.0.0.1 D:\lihongfeng\workspace\untitled\index.php
export XDEBUG_CONFIG="idekey=session_name" // 設定環境變數 echo $XDEBUG_CONFIG // 檢視環境變數 unset XDEBUG_CONFIG // 刪除環境變數
set XDEBUG_CONFIG="idekey=session_name" // 設定環境變數 echo %XDEBUG_CONFIG% // 檢視環境變數 set XDEBUG_CONFIG // 檢視環境變數 set XDEBUG_CONFIG= // 刪除環境變數
推薦學習:《》
以上就是PHP中有哪些debug方法的詳細內容,更多請關注TW511.COM其它相關文章!