玩转 PhpStorm 系列(九):代码调试篇(上)

前面的教程大多围绕的是如何提高 PhpStorm 的日常编码效率,无论是代码导航、插件、快捷键还是代码模板、代码重构,都是围绕着效率展开。接下来,学院君来给大家介绍一些效率以外的主题,比如调试、测试以及编码风格。

首先我们来看调试。

在 PHP 生态中,最有名的调试工具莫过于 Xdebug:

Xdebug

所以,接下来,我们就以 Xdebug 为例演示如何在 PhpStorm 中对 PHP 代码进行调试。安装配置 Xdebug 扩展

使用 Xdebug 对代码进行调试前,先要安装对应的 PHP 扩展。

以 Mac 系统为例,我们可以在终端窗口通过 指令查看是否已经安装 Xdebug 扩展:

在 Zend Mdoules 列表中可以看到「Xdebug」即表示安装成功。如果还没有安装,可以参考 Xdebug 官方文档进行安装。

除此之外,还需要通过配置文件对 Xdebug 尽心配置,可以通过 命令查看 PHP 配置文件路径:

这里,我们在 中配置 Xdebug 配置如下(当然,你可以选择在 目录下新建一个 对 Xdebug 进行单独配置,PHP 会自动加载对应的配置文件):

这里我们启用了远程监听(包括 IP 地址和端口设置)、脚本分析、以及设置 为 ,关于调试和分析配置项细节和含义,请参考 Xdebug 官方提供的调试设置和脚本分析文档。

完成以上准备工作后,可以在任意空目录下新建 ,在其中编写如下 PHP 脚本:

然后运行 来启动 PHP 内置 HTTP 服务器,在浏览器访问 ,查看 PHP 中 Xdebug 扩展配置是否生效:

配置 PHP CLI 解释器

接下来,我们就可以在 PhpStorm 中通过 Xdebug 来调试 PHP 代码了。

开始进行代码调试前,先在 Preferences | Languages & Frameworks | PHP 中配置 PHP CLI 解释器:

如果你的 PhpStorm 中当前 CLI Interpreter 一栏显示 的话,可以点击右侧「…」 按钮添加:

注:你也可以在这里看到相应的 Debugger 扩展是 Xdebug 2.9.6 版本,如果这里没有检测到对应的 Xdebug 扩展信息,表明该版本的 PHP 没有安装这个扩展,需要参考上面的安装设置步骤进行安装配置。

在 Name 框输入 CLI 解释器的名称,在 PHP executable 框输入当前系统 PHP 二进制文件的路径即可,如果不知道,可以在终端窗口运行 命令查看。调试 PHP CLI 脚本代码

接下来,我们先来看一个本地 PHP CLI 脚本代码的调试。我们首先编写一段测试代码 ,这段代码的作用是打印九九乘法表:

我们在终端窗口执行这段代码,打印结果如下:

如果在代码执行过程中报错,或者想要了解代码执行的完整流程,可以在代码编辑区从指定位置设置断点(从任意你想要调试的位置开始):

-w736

然后在 PhpStorm 导航菜单点击 Run->Debug…(或者通过快捷键 Ctrl + Option + D):

在弹出窗口选择要调试的 PHP 脚本:

即可进入 PHP CLI 脚本的调试流程:

接下来,你可以点击上图红框内的按钮进行断点调试,将鼠标移到对应的按钮上会出现提示文本,比如 Step Over 表示跳过当前这一行,Step Into 表示进入函数内部等等,这里我们可以点击通过 Step Into(第二个按钮)逐行调试代码,在调试过程中,你可以实时看到当前作用域内变量的值:

这样,可以及时感知代码当前的执行状态,从而对出现问题的地方进行定位和排查原因。如果代码逻辑很复杂,变量很多,还可以通过将关心的变量添加到监控区进行查看:

(全文完)