PhpStorm配置Xdebug最完整最详解教程

本文最后更新于:2023年10月19日 晚上

前言

PhpStorm配置Xdebug最完整最详解教程,100%成功!

很多人好奇网上关于php配置xdebug的教程那么多,为什么我还要写这篇文章?
因为网上的教程配置很乱,很多都是复制粘贴,有些配置项根本不需要,也不解释干嘛的,而且不够详细。

本教程主要应用于Windows,Mac和Linux基本上同理。

配置xdebug扩展

只配置Debug,不配置profiler和trace,profiler和trace干嘛的请百度。
因为大多数情况下是单用户调试,所以不需要配置多用户参数,
如:php.ini 文件 xdebug.idekey 参数和 PhpStorm的Debug -> DBGp Proxy 。

所以php.ini大概配置如下:

1
2
3
4
5
zend_extension = php_xdebug.dll
xdebug.remote_enable = On
xdebug.remote_host = 127.0.0.1
xdebug.remote_port = 9100

xdebug官网下载地址:https://xdebug.org/download.php
扩展一定要装对,注意区分ts和nts版本,phpinfo()查看扩展是否成功。
推荐 phpEnv集成环境 ,自带xdebug扩展和多版本php

设置PhpStorm

打开PhpStorm,菜单 File -> Settings ,然后找到 Languages & Frameworks -> PHP -> Debug
设置Debug port9100
为什么不是9000?因为会和一些集成环境的php-cgi或者php-fpm端口冲突.

然后配置Languages & Frameworks -> PHP -> Servers
20190424122001895.png

然后找到PhpStorm右上角电话图标,开始监听php debug的链接

20190424122014390.png

打开 phpEnv集成环境 的 TCP端口进程列表,有9100端口,说明监听成功

20190424122027298.png

触发断点调试

在你需要的代码处打断点,这是基础和必须,就不多介绍了。
20190424122045766.png

触发PhpStorm的debug方式主要有两种

  1. GET、POST存在XDEBUG_SESSION_START 参数或者cookie里存在XDEBUG_SESSION,单用户调试 值随意。GET、POST会生成cookie XDEBUG_SESSION,有效期为1个小时(可修改php.ini配置)。很多教程需要下载Xdebug helper等浏览器插件,原理就是请求里附加cookie。
  2. php.ini 文件 xdebug.remote_autostart 参数设置为 On 或者1,无需设置GET、POST、cookie。(不推荐,虽然不需要设置参数,设置针对环境,而不是项目,还要重启php环境)

浏览器调试

针对第 1 种,教大家用一种更简单的方式,不需要下载浏览器插件。
找到PhpStorm右上角

20190424122127588.png
然后点小甲虫图标
2019042412214398.png
会打开浏览器访问你的url,并且携带GET参数XDEBUG_SESSION_START,同时生成cookie XDEBUG_SESSION,也就是说,下次(cookie有效期1小时)无需点击小甲虫,浏览器直接输入,如 www.a.comwww.a.com/chat/1/ 即可触发调试

20190424122152416.png

Postman接口调试

针对第 1 种,Postman触发方式如图
20200728180909682.png
可以直接添加GET、POST参数,在请求结束后,会自动附加cookie XDEBUG_SESSION,也可以手动添加cookie XDEBUG_SESSION