新聞中心
本教程操作環(huán)境:windows7系統(tǒng)、PHP7.1版、DELL G3電腦

創(chuàng)新互聯(lián)建站-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比阜陽網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式阜陽網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋阜陽地區(qū)。費(fèi)用合理售后完善,10多年實(shí)體公司更值得信賴。
通過瀏覽器打印信息進(jìn)行調(diào)試
方法
在代碼中添加 echo、var_dump、print_r 和 exit,在瀏覽器中查看輸出。
優(yōu)缺點(diǎn)
優(yōu)點(diǎn):
- 簡單,使用方便,不用安裝插件
- 對于自己寫的代碼,或比較熟悉的框架,可以這么用
缺點(diǎn):
- 對于多分支邏輯,需要加很多代碼或嘗試多次
- 對于不熟悉的邏輯,無法反映出完整的執(zhí)行流程。
- 有可能將調(diào)試語句遺漏在項(xiàng)目中
- 無法單步執(zhí)行
技巧
調(diào)試時,為了格式化輸出變量,往往需要在項(xiàng)目中實(shí)現(xiàn)自己的 dump() 函數(shù)。利用 Composer,可以全局安裝 symfony/var-dumper 包中的 dump() 函數(shù),使所有項(xiàng)目都可以使用,而無需改動項(xiàng)目。
- 全局安裝
symfony/var-dumper包:
默認(rèn)會安裝到${HOME}/.config/composer目錄
composer global require symfony/var-dumper
- 修改
php.ini文件,執(zhí)行 PHP 代碼之前先 include 指定的文件
auto_prepend_file = ${HOME}/.config/composer/vendor/autoload.php
使用 Xdebug 進(jìn)行調(diào)試
XDebug 是 C/S 結(jié)構(gòu),其中 Client 是 PHP 中安裝的 Xdebug,Server 是 IDE 中安裝的插件,使用 DBGP 協(xié)議通信。PHP 運(yùn)行腳本時,通過 Xdebug 插件向 IDE 發(fā)送調(diào)試信息,并接收 IDE 發(fā)過來的控制信號。
需要為 PHP 安裝并開啟 Xdebug,然后設(shè)置 IDE 的 Xdebug 插件,使二者可以通信。
優(yōu)缺點(diǎn)
- 支持單步調(diào)試和任意變量值的獲取
- 配置復(fù)雜,需要 IDE 安裝插件
- 支持跟瀏覽器的配合,需要請求中攜帶
XDEBUG_SESSION_START參數(shù)
Web App 調(diào)試
對于 web 應(yīng)用,要開啟 Xdebug 調(diào)試模式,必須在瀏覽器發(fā)送的請求中添加額外的標(biāo)志??梢栽?GET/POST/Cookie 參數(shù)中添加 XDEBUG_SESSION_START=session_name,這樣 Xdebug 就明白這個請求需要調(diào)試,去連接 IDE。
但每次手工設(shè)置也很麻煩,有兩種方式簡化操作:
- 使用 IDE 提供的方式。對于 PhpStorm,參考 Debugging PHP Web Applications with Run Debug Configurations。使用時需要配置好 IDE 中的 Web Server,然后設(shè)置一個 PHP Web Application,點(diǎn)擊 Debug 按鈕開始調(diào)試,這時 IDE會自動打開瀏覽器并輸好網(wǎng)址,并添加
XDEBUG_SESSION_START=session_name。 - 使用瀏覽器插件,打開插件的調(diào)試開關(guān)后,插件可以自動在請求中帶上對應(yīng)的 Cookie。對于 Chrome 可以安裝 Xdebug helper。
通過 console 終端進(jìn)行調(diào)試(CLI 方式)
對于非 web 應(yīng)用,例如定時任務(wù)或單元測試,可以直接在控制臺進(jìn)行調(diào)試。
PhpStorm 中通過 Alt+F12 快捷鍵打開命令行終端。但是因?yàn)?IDE 中只能顯示一個終端,在開啟調(diào)試后的調(diào)試終端會覆蓋命令行終端,所以還是單獨(dú)開一個命令行終端吧(Windows 下可以使用 DOS 窗口或 PowerShell)。
方法及原理
web 應(yīng)用通過 GET/POST/Cookie 參數(shù)標(biāo)志調(diào)試請求,而非 web 應(yīng)用則通過在命令行終端設(shè)置環(huán)境變量來開啟調(diào)試。
兩步:
- 設(shè)置環(huán)境變量
XDEBUG_CONFIG="idekey=session_name",這個 idekey 需要跟php.ini中 Xdebug 部分設(shè)置的 idekey 一樣。 - 在命令行終端執(zhí)行腳本。執(zhí)行時會喚起 IDE 的 debug 終端,可以單步調(diào)試,輸出結(jié)果實(shí)時顯示在命令行終端。
IDE通常提供快捷操作,對于 PHPStorm 可以參考 Debugging PHP CLI scripts with PhpStorm。
通過 IDE 啟動調(diào)試后,IDE 會啟動 Xdebug 插件監(jiān)聽某個端口(PhpStorm 默認(rèn)是 9000,但是這跟 PHP-FPM 沖突了,可以改為 9001),獲取 PHP 服務(wù)器返回的調(diào)試信息。
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
設(shè)置、查看和釋放環(huán)境變量
- Linux
export XDEBUG_CONFIG="idekey=session_name" // 設(shè)置環(huán)境變量 echo $XDEBUG_CONFIG // 查看環(huán)境變量 unset XDEBUG_CONFIG // 刪除環(huán)境變量
- Windows
set XDEBUG_CONFIG="idekey=session_name" // 設(shè)置環(huán)境變量 echo %XDEBUG_CONFIG% // 查看環(huán)境變量 set XDEBUG_CONFIG // 查看環(huán)境變量 set XDEBUG_CONFIG= // 刪除環(huán)境變量
網(wǎng)頁題目:PHP中有哪些debug方法
分享路徑:http://fisionsoft.com.cn/article/djjopcg.html


咨詢
建站咨詢
