VS Code 调试 PHP 必须同时配置 Xdebug 3(PHP 端)和 PHP Debug 插件(VS Code 端),关键在于 php.ini 中启用 zend_extension、设置 xdebug.mode=debug 与 client_port=9003,并在 launch.json 中匹配 port 和 pathMappings。
VS Code 能调试 PHP,但不是开箱即用——必须同时配对 Xdebug 3(PHP 端)和 PHP Debug 插件(VS Code 端),缺一不可。断点不触发、连接超时、变量为空,90% 都是这两端配置没对齐。
这是整个流程的地基。很多人卡在“点了 F5 没反应”,其实 VS Code 根本没收到连接请求。
php -m | grep xdebug,有输出才说明扩展已启用;无输出就别往下走了php.ini(用 php --ini 找准确路径),Xdebug 3 必须用以下写法(不是旧版的 xdebug.remote_enable=1):[xdebug] zend_extension=xdebug xdebug.mode=debug xdebug.start_with_request=yes xdebug.client_host=127.0.0.1 xdebug.client_port=9003 xdebug.log=/tmp/xdebug.log
xdebug.client_port=9003 是关键,默认值,VS Code 插件也默认连这个端口;若改了,两边必须同步改launch.json
只装「PHP」扩展不够,它只提供语法高亮和跳转;真正收 Xdebug 连接的是 PHP Debug 插件(作者:felixfbecker)。
PHP Debug,安装后重启 VS CodeF5 → 选 P
HP → 自动生成 .vscode/launch.json
port 和 pathMappings,其余保持默认即可{
"version": "0.2.0",
"configurations": [
{
"name": "Listen for Xdebug",
"type": "php",
"request": "launch",
"port": 9003,
"pathMappings": {
"/var/www/html": "${workspaceFolder}"
}
}
]
}
port 必须等于 php.ini 中的 xdebug.client_port
pathMappings 左边是 PHP 实际运行时看到的绝对路径(比如 Docker 容器里是 /var/www/html,XAMPP 是 C:/xampp/htdocs),右边是你的本地项目文件夹;映射错一个字符,断点就永远不命中两种方式本质一样,都是让 PHP 主动连回 VS Code。区别在于你当前开发场景。
http://localhost/index.php?XDEBUG_SESSION_START=1,或装浏览器插件「Xdebug Helper」自动加参数launch.json 中额外加一个配置:{
"name": "Launch currently open script",
"type": "php",
"request": "launch",
"program": "${file}",
"cwd": "${fileDirname}",
"port": 9003
}
test.php → 按 F5 → 选这个配置 → 就会直接执行该脚本并进断点xdebug.start_with_request=yes 仍需开启,否则不触发常见现象:程序停在断点,调用堆栈正常,但「变量」面板空空如也,或显示 undefined。
Xdebug listening on 127.0.0.1:9003?没显示说明监听根本没起来xdebug.log(按配置路径找),搜索 Connection failed 或 Failed to connect,大概率是防火墙拦截、Docker 网络不通、或 client_host 写成了 localhost(某些系统解析失败,必须用 127.0.0.1)xdebug.client_host 不能写 127.0.0.1(那是容器自己),得填宿主机 IP(如 172.17.0.1),且 pathMappings 左边必须是容器内路径最常被忽略的一点:Xdebug 日志默认不开启,而它是唯一能告诉你“到底连没连上”的证据。只要调试异常,第一反应不是重装,而是打开 xdebug.log 看第一行错误。