PHP中有哪些debug方法

2022-02-21 16:00:39

PHP中的debug(偵錯)方法有:1、在PHP程式碼中新增echo、var_dump、print_r和exit語句,通過瀏覽器列印資訊進行偵錯;2、使用Xdebug進行偵錯;3、通過console終端進行偵錯。

本教學操作環境:windows7系統、PHP7.1版、DELL G3電腦

PHP常用的debug(偵錯)方式

通過瀏覽器列印資訊進行偵錯

方法

在程式碼中新增 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 外掛,使二者可以通訊。

優缺點

  • 支援單步偵錯和任意變數值的獲取
  • 設定複雜,需要 IDE 安裝外掛
  • 支援跟瀏覽器的配合,需要請求中攜帶 XDEBUG_SESSION_START 引數

Web App 偵錯

對於 web 應用,要開啟 Xdebug 偵錯模式,必須在瀏覽器傳送的請求中新增額外的標誌。可以在 GET/POST/Cookie 引數中新增 XDEBUG_SESSION_START=session_name,這樣 Xdebug 就明白這個請求需要偵錯,去連線 IDE。

但每次手工設定也很麻煩,有兩種方式簡化操作:

  • 使用 IDE 提供的方式。對於 PhpStorm,參考 Debugging PHP Web Applications with Run Debug Configurations。使用時需要設定好 IDE 中的 Web Server,然後設定一個 PHP Web Application,點選 Debug 按鈕開始偵錯,這時 IDE會自動開啟瀏覽器並輸好網址,並新增 XDEBUG_SESSION_START=session_name
  • 使用瀏覽器外掛,開啟外掛的偵錯開關後,外掛可以自動在請求中帶上對應的 Cookie。對於 Chrome 可以安裝 Xdebug helper。

通過 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 的 debug 終端,可以單步偵錯,輸出結果實時顯示在命令列終端。

這裡寫圖片描述

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

設定、檢視和釋放環境變數

  • Linux
export XDEBUG_CONFIG="idekey=session_name" // 設定環境變數
echo $XDEBUG_CONFIG // 檢視環境變數
unset XDEBUG_CONFIG // 刪除環境變數
  • Windows
set XDEBUG_CONFIG="idekey=session_name" // 設定環境變數
echo %XDEBUG_CONFIG% // 檢視環境變數
set XDEBUG_CONFIG // 檢視環境變數
set XDEBUG_CONFIG= // 刪除環境變數

推薦學習:《》

以上就是PHP中有哪些debug方法的詳細內容,更多請關注TW511.COM其它相關文章!