掃二維碼與項(xiàng)目經(jīng)理溝通
我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢(xún)/運(yùn)營(yíng)咨詢(xún)/技術(shù)建議/互聯(lián)網(wǎng)交流
本教程操作環(huán)境:windows7系統(tǒng)、PHP7.1版、DELL G3電腦

創(chuàng)新互聯(lián)建站-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性?xún)r(jià)比阜陽(yáng)網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式阜陽(yáng)網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋阜陽(yáng)地區(qū)。費(fèi)用合理售后完善,10多年實(shí)體公司更值得信賴(lài)。
通過(guò)瀏覽器打印信息進(jìn)行調(diào)試
方法
在代碼中添加 echo、var_dump、print_r 和 exit,在瀏覽器中查看輸出。
優(yōu)缺點(diǎn)
優(yōu)點(diǎn):
缺點(diǎn):
技巧
調(diào)試時(shí),為了格式化輸出變量,往往需要在項(xiàng)目中實(shí)現(xiàn)自己的 dump() 函數(shù)。利用 Composer,可以全局安裝 symfony/var-dumper 包中的 dump() 函數(shù),使所有項(xiàng)目都可以使用,而無(wú)需改動(dòng)項(xiàng)目。
symfony/var-dumper 包: ${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)行腳本時(shí),通過(guò) Xdebug 插件向 IDE 發(fā)送調(diào)試信息,并接收 IDE 發(fā)過(guò)來(lái)的控制信號(hào)。
需要為 PHP 安裝并開(kāi)啟 Xdebug,然后設(shè)置 IDE 的 Xdebug 插件,使二者可以通信。
優(yōu)缺點(diǎn)
XDEBUG_SESSION_START 參數(shù)Web App 調(diào)試
對(duì)于 web 應(yīng)用,要開(kāi)啟 Xdebug 調(diào)試模式,必須在瀏覽器發(fā)送的請(qǐng)求中添加額外的標(biāo)志??梢栽?GET/POST/Cookie 參數(shù)中添加 XDEBUG_SESSION_START=session_name,這樣 Xdebug 就明白這個(gè)請(qǐng)求需要調(diào)試,去連接 IDE。
但每次手工設(shè)置也很麻煩,有兩種方式簡(jiǎn)化操作:
XDEBUG_SESSION_START=session_name。通過(guò) console 終端進(jìn)行調(diào)試(CLI 方式)
對(duì)于非 web 應(yīng)用,例如定時(shí)任務(wù)或單元測(cè)試,可以直接在控制臺(tái)進(jìn)行調(diào)試。
PhpStorm 中通過(guò) Alt+F12 快捷鍵打開(kāi)命令行終端。但是因?yàn)?IDE 中只能顯示一個(gè)終端,在開(kāi)啟調(diào)試后的調(diào)試終端會(huì)覆蓋命令行終端,所以還是單獨(dú)開(kāi)一個(gè)命令行終端吧(Windows 下可以使用 DOS 窗口或 PowerShell)。
方法及原理
web 應(yīng)用通過(guò) GET/POST/Cookie 參數(shù)標(biāo)志調(diào)試請(qǐng)求,而非 web 應(yīng)用則通過(guò)在命令行終端設(shè)置環(huán)境變量來(lái)開(kāi)啟調(diào)試。
兩步:
XDEBUG_CONFIG="idekey=session_name",這個(gè) idekey 需要跟 php.ini 中 Xdebug 部分設(shè)置的 idekey 一樣。IDE通常提供快捷操作,對(duì)于 PHPStorm 可以參考 Debugging PHP CLI scripts with PhpStorm。
通過(guò) IDE 啟動(dòng)調(diào)試后,IDE 會(huì)啟動(dòng) Xdebug 插件監(jiān)聽(tīng)某個(gè)端口(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
export XDEBUG_CONFIG="idekey=session_name" // 設(shè)置環(huán)境變量 echo $XDEBUG_CONFIG // 查看環(huán)境變量 unset XDEBUG_CONFIG // 刪除環(huán)境變量
set XDEBUG_CONFIG="idekey=session_name" // 設(shè)置環(huán)境變量 echo %XDEBUG_CONFIG% // 查看環(huán)境變量 set XDEBUG_CONFIG // 查看環(huán)境變量 set XDEBUG_CONFIG= // 刪除環(huán)境變量

我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢(xún)/運(yùn)營(yíng)咨詢(xún)/技術(shù)建議/互聯(lián)網(wǎng)交流