在 VSCode 里调试 PHP

1 下载对应版本的 Xdebug

  1. 在命令行里运行
    php -i
    // 又或者运行这句
    php -r 'phpinfo();'
    
  2. 打开这个网址 https://xdebug.org/wizard.php 把第一步输出的结果复制进去,然后获得对应版本 Xdebug 的下载地址,当然如果你知道熟悉 PHP 的版本也可以直接选择相应的版本下载
  3. 解压下载后的压缩包,把 Xdebug 的拓展复制进 PHP 的拓展目录里,PHP 的拓展目录一般是安装目录里的 ext 文件夹

2 修改 php.ini

在 php.ini 的最后加上以下内容

2.9 配置参考文档

3 安装 VSCode 的 PHP 拓展包

在 VSCode 的拓展里搜索对应的插件名然后选择安装即可。

IntelliSense 的插件有两个, IntelliSense 只需要装一个就可以的了,笔者更喜欢用 PHP Intelephense 。

4 在 VSCode 里设置 Xdebug

  1. 使用 VSCode 以打开文件的方式,打开需要调试的 PHP 项目所在的文件夹
  2. 在 VSCode 里选择调试,然后选添加配置,然后选 PHP
  3. 这时 VSCode 会在 launch.json 自动添加 Xdebug 的相关配置,如果 lanuch.json 不存在则会自动新建,如果是调试 PHP 一般不用修改 lanuch.json 的默认内容,大多数情况下监听的端口都是 9003

5 调试

如果配置启用了自动调试,那么脚本的运行命令就不需要额外的参数, 浏览器也不需要 Xdebug Helper 插件。 但是这样会所有请求都启用调试。

命令行

  1. 在 VSCode 打开的文件夹里新建一个 PHP 脚本
  2. 在这个脚本里设置一个断点,然后点击开始调试
  3. 然后用这样的命令执行脚本
    • xdebug 2.9
      php -d xdebug.remote_autostart=on test.php
      
    • xdebug 3.0
      php -d xdebug.start_with_request=yes test.php
      
    • 在环境变量中,把 XDEBUG_SESSION 的值设为和配置中 idekey 的值一样也能触发调试
      export XDEBUG_SESSION=vscode; php test.php
      export XDEBUG_SESSION=vscodetest; php -d xdebug.idekey=vscodetest test.php
      set XDEBUG_SESSION=vscode && php test.php
      $Env:XDEBUG_SESSION = "vscode"; php test.php
      
  4. 如无意外,当代码运行到断点时会自动停止

web

  1. 在浏览器里安装 Xdebug Helper ,在浏览器的拓展搜索 Xdebug Helper 即可
  2. 在 Xdebug 的配置里添加这一项 xdebug.idekey
    xdebug.idekey = "vscode"
    
  3. 设置 Xdebug Helper 的 IDE Key 为 other ,vaule 为 vscode
  4. 这是点击,浏览器地址栏右边的 debug 图标就可以进行调试了
  5. 然后在浏览器里访问对应的地址
  6. Xdebug Helper 实现的原理是, xdebug.idekey 的值会添加到 cookies 里(大概像这样 XDEBUG_SESSION=vscode ), php 检测到 xdebug.idekey 后就会通知 IDE 启动调试
  7. 用 postman 或 curl 这类工具测试时,只要 http 头的 cookie 带有 XDEBUG_SESSION=vscode ,就是触发调试的了,类似于这样
    curl -k --cookie "XDEBUG_SESSION=vscode" http://testurl
    

6. 使用分析工具

profiler 文件可以用 QCacheGrind 查看; trace 的文件是纯文本的,可以直接打开的。

QCacheGrind

  1. QCacheGrind 不支持 xdebug 3.0
  2. 下载 QCacheGrind
    https://sourceforge.net/projects/qcachegrindwin/
    
  3. Xdebug 的配置里需要有这两项, xdebug.profiler_output_dir 是分析文件的输出目录
    xdebug.profiler_enable = on
    xdebug.profiler_output_dir = ""
    
  4. 启动调试后,在这个目录里 xdebug.profiler_output_dir 找到分析文件,并使用 QCacheGrind 打开
  5. 分析文件的文件名通常是 cachegrind.out.7468 后面的数字是进程ID。

Webgrind

https://github.com/jokkedk/webgrind

其它