hhxpnzdnh 2019-07-01
使用PHPSTORM
以及xdebug
有些时间了,但每次一切换环境,貌似xdebug
都会来点小问题。于是,准备花时间系统的将配置及排查的过程写一下,以便下次使用的时候,能够不再重复走过去的路。
安装xdebug
扩展略过。
再借用动图一张:
感谢原作者的辛苦付出, 点击查看原文
有了上面的原理,在配置的时候,我们就有了方向。
步骤如下:
xdebug
安装后,需要配置相应的php.ini
文件
# 开启远程调试 xdebug.remote_enable=1 # 定义日志位置,很重要。当发生一些与我们的预期不一致的事件时,我们可以找到这个文件查看。 xdebug.remote_log=/var/log/xdebug.log # 远程调试服务器(我们开发的装有PHPSTORM机器)的端口,默认就是这个端口,所以如果你就是用的9000,此项可忽略。 xdebug.remote_port=9000 # 远程调试服务器(我们开发的装有PHPSTORM机器)的地址,如果`XDEBUG`和`PHPSTORM`都是一台机器上,那么这个地址写127.0.0.1即可. xdebug.remote_host=127.0.0.1 # 定义IDE KEY。定义后,可以忽略。 xdebug.idekey=PHPSTORM
注意:查看日志很重要,所以xdebug.remote_log
此项配置很重要。
创建test.php
并输入<?php phpinfo();
,访问该文件,查看debug
信息。
同时,还可以看到一些配置信息:
打开配置界面 -> Languages & Frameworks -> PHP -> Debug
此项默认开启,故可忽略
点击确定后,按系统不同,可以查看本机9000
端口是否开放。
panjiedeMac-Pro:~ panjie$ lsof -i:9000 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME PHPSTORM 98883 panjie 293u IPv4 0x9dffc3bec4b8f68b 0t0 TCP *:cslistener (LISTEN)
端口直接的启动后,我们便设置好的调试服务器 127.0.0.1
和端口9000
了。这时候,我们的xdebug
便可以找到我们
打开配置界面 -> Languages & Frameworks -> PHP
点击 + , 并选择自己的PHP环境。
chrome
安装xdebug helper
,firefox
也类似。作用主要是向cooikes
写一个XDEBUG_SESSION=PHPSTORM
。安装后,设置一下,否则默认的是eclipse
。
xdebug helper
点击enable
后,刷新页面。
此时:
XDEBUG_SESSION=PHPSTORM
发送给PHP
PHP
将控制权给了xdebug
xdebug
获取到XDEBUG_SESSION
时,与自己的设定时进行比较,相同,则向127.0.0.1:9000
发送信息,并中断执行PHPSTORM
接收到信息,将信息显示到控制台,并对应的在对应的文件上显示断点,同时发出中断执行指令PHPSTORM
发出继续执行指令进行下一步debug.