XDEBUG+PHPSTORM 开发 调试

XDEBUG+PHPSTORM 开发 调试

在我们开发过程中。我们如果经常性的echo、dump效率很低。所以我们就可以使用xdebug进行断点调试。

下面的教程以 Windows 操作系统为例子。其他操作系统类似。

1. 下载xdebug

安装xdebug前,请确定自己的php版本和使用的TS或NTS。如果实在不清楚,可以通过以下方式查看

1536130176419

如上图,第一个红框就是现在使用的php的版本,

第二个框就是你使用php编译的X86还是X64.

第三个是表示加载的php.ini的位置。我们会用到,后面需要改php.ini。就是改这个位置。一定不能改错了。

第四个框,就是Thread Safety 如果是 diabled 就表示我们用的PHP是NTS的。如果是enable 就代表是TS的。待会选择xdebug的时候就会用到上面的信息。

下载地址:https://xdebug.org/download.php

根据我们上图的信息,我们选择的应该是php7.1 x86 nts的 xdebug拓展

32bit 就是32位操作系统。也就是x86. 如果后面没有写TS ,就代表这个拓展是NTS的。不要选错了。

1536130606998

2. 安装Xdebug

将我们上面下载好的拓展移动到 php 的 extension_dir 的目录。如果不知道自己的拓展目录在哪。还是可以通过phpinfo查看

搜索 extension_dir 就是拓展所在的目录。

1536130879493

3. 配置Xdebug

打开 php.ini php.ini 的位置。通过**phpinfo()**中进行查看。 以免改错位置。

在后面加上一下配置

[Xdebug]
;拓展的位置。这里一定要zend_extesion
zend_extension="php_xdebug-2.7.0alpha1-7.1-vc14-nts.dll"
;启用性能检测分析
xdebug.profiler_enable=on
;启用代码自动跟踪
xdebug.auto_trace=on
;允许收集传递给函数的参数变量
xdebug.collect_params=on
;允许收集函数调用的返回值
xdebug.collect_return=on
xdebug.remote_enable=1
xdebug.remote_handle="dbgp"
xdebug.remote_mode="req"
xdebug.remote_host="localhost"
;端口 可以自己更改,不要冲突,待会需要用到
xdebug.remote_port=9002
xdebug.idekey="PHPSTORM"
xdebug.collect_includes = 1
xdebug.remote_autostart = 1
;指定堆栈跟踪文件的存放目录
xdebug.trace_output_dir="D:/debug"
;指定性能分析文件的存放目录
xdebug.profiler_output_dir="D:/debug"
xdebug.profiler_output_name = cachegrind.out.%t.%p

4. 验证Xdebug

验证Xdebug。同样使用我们的 phpinfo 进行验证。记得改完配置,记得重启apache或者nginx 或者其他的web服务器

1536131596474

1536131772127

搜索xdebug。 看到上面的界面就是配置成功了。然后再检查上面的配置是不是和你设置的一致。

PHPSTORM 整合Xdebug 进行断点调试

1. 配置Cli Interpreter

settings -->Languages Frameworks ---> PHP

点击红框内的 ...

1536132188638

  • 先点击下图的 + 添加一个新的cli 。

  • 点击 ... 选择你的php.exe的位置。 这个php 一定是你的web用的。跟我们配置Xdebug的要一样。

    选择了之后,底下就会检测到我们的php的版本,和xdebug版本以及php.ini的配置。如果这里的信息和我们phpinfo 看到的不一样,就要检查下,是不是选择的php的版本不对。

1536132302256

2. 配置debug

settings -->Languages Frameworks ---> PHP --->Debug

1536132609448

更改红框中的端口为我们在php.ini中的配置的端口。我们在php.ini配置了9002.所以这里也要写上9002.不要写错了。否则就会有问题。

  • 然后再点击我们DBGp Proxy

1536132748160

红框中的配置。按照我们在php.ini中的配置进行填写。

xdebug.idekey="PHPSTORM"
xdebug.remote_host="localhost"
xdebug.remote_port=9002

3. 配置Server

1536131936983

然后自己本地需要debug的host 、 端口

1536133092580

4. edit cofigure

点击菜单栏中的run。 然后点击edit Congiurations

1536133451273

在出来后的选项中,点击 + 然后选择 PHP Web Page

1536133508626

选择你刚才 添加的 server 以及起始的web地址。 点击 apply 应用

1536133605461

6.开启监听

点击下图中的这个小电话的图标。 让你变绿色。

没有监听的状态

1536133804975

正在监听的状态

1536133911407

7. 开启调试

在我们需要调试的代码处,我们需要加上一个断点,然后程序运行到这个地方,就会停下来。下面以TP5为例子。

1536134070135

然后我们运行我们的项目。就会发现浏览器卡住了,这个时候,我们打开PHPstorm。就会发现。程序停下来了。

1536134215544

我们可以很清晰的看到上下文的变量的值。以及框架的执行的流程。这对我们分析一个框架,是很有帮助的。

然后我们可以进行单步调试,或者步入、跳出等操作

1536135094157

图中,所有画红圈的就是常用到的工具。其具体功能介绍如下:

  • 重新请求

img

此工具,点击后,当前调试所有变量全部销毁,重新开启一轮请求。即如同刷新页面。

  • 执行到下一个断点,暂停

img

此工具点击后,继续 Laravel 生命进程的路程,直到下一个断点,暂停

  • 停止调试

img

此工具,停止调试,结束 Laravel 周期。

  • 变量栏

img

变量栏标签,下面的内容是当前调试位置所有能够用到的变量(包含全局和局部),记住能用到就会显示

  • 定位到当前调试的文件以及行

img

此工具的作用是当调试行文件关闭了,或者代码视图跑到其它位置了,点击它,就能重新定位到调试文件以及调试行

  • 跳过当前调试行代码要执行函数,直接返回结果

img

此工具的作用是当调试行代码有调用函数,包含文件,new 新对象时,能够不进入相应函数、文件、类中,直接返回其调用的结果,在当前行中,执行下文

  • 进入和强制进入调用的函数内

img

此工具功能正好和上面的相反,即进入和强制进入当前调试行将要调用的函数、方法、包含的文件、new的新对象类文件中,执行相应代码

  • 跳出正在调用的函数

img

跳出正在执行的函数、方法、包含的文件、new 新对象的类文件,至调用行,并继续执行调用行下面的代码

posted @ 2018-09-06 00:26  闲云-野鹤  阅读(481)  评论(0编辑  收藏  举报