zoukankan      html  css  js  c++  java
  • 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 新对象的类文件,至调用行,并继续执行调用行下面的代码

  • 相关阅读:
    Dockerfile使用案例
    Centos创建sudo用户免密使用
    yaml实例
    k8s学习过程中需要注意的地方
    docker部署redmine项目管理软件
    kubernetes陈述式常用命令
    mysql误删除数据后如何恢复
    kubeadm安装的k8s集群卸载方式
    虚拟机vmware centos7 扩展磁盘空间
    'React/RCTBundleURLProvider.h' file not found
  • 原文地址:https://www.cnblogs.com/tl542475736/p/9595701.html
Copyright © 2011-2022 走看看