使用PHPStorm+XDebug搭建单步调试环境


Posted in PHP onNovember 19, 2017

PHP是一个解释执行的语言,一般来说,进行调试的时候,只要通过使用 var_dump 或者 var_export 两个函数,就可以得到PHP中变量的值,达到调试的地步,但是对于大型项目,或者想研究一下别人的代码时,使用单步调试会变得简单的多。就拿目前最流行的 PHP Laravel 框架为例子,使用 PHPStorm 搭建单步调试环境。

PHPStorm安装和基本配置

PHPStorm下载安装

PHPStorm除了体积有些大外,算是PHP IDE中非常强大便捷的开发环境。官网下载地址:https://www.jetbrains.com/phpstorm/

本站下载地址 点击下载

PHPStorm激活

安装之后需要激活,如果经济能力许可,可以购买正版,当然,网上也有很多激活方式。这儿需要提醒的是,如果你激活不了,可是试试在 host 中添加下面这一行 0.0.0.0 account.jetbrains.com

PHPStorm设置字体大小

打开PHPStorm以后,可以在选择菜单 File -> Settings -> Editor -> Colors & Fonts -> Font ,在右边显示的信息栏中设置自己习惯的字体和大小。

PHPStorm导入项目

可以在PHPStorm中选择:File -> Open,直接打开工作文件夹,一般我喜欢把所有的PHP项目放在一个 PHP_Projects 的文件夹下,然后统一打开,便于开发,一面频繁切换工作空间。

PHPStorm标记项目位置

一般情况下,打开的文件夹下面会有很多项目,我们需要标记这些项目,这样能够提供更好的索引和代码之间关联。
菜单选择:File -> Settings -> Directories,然后把每个项目的根目录标记为 Sources。

安装XDebug扩展

下载XDebug扩展

为了调试PHP,我们还需要一个PHP扩展:xDebug,这是一个非常强大的PHP调试扩展,用来最终PHP执行过程,执行堆栈等。xDebug官方下载地址:https://xdebug.org/,点击每个版本说明中的 download 连接即可进入下载页面,注意这儿需要选择适合自己系统版本和PHP版本的xdebug扩展。

配置xdebug扩展

下载之后解压缩,里面包含一个 dll 格式或者 so 格式的动态链接库,我们把它放在PHP安装目录的ext文件夹下,然后配置PHP.ini。需要在PHP最后添加xdebug的配置。

[xdebug]
zend_extension="C:\Devlope\wamp\php7.16\ext\php_xdebug-2.5.5-7.1-vc14-x86_64.dll"
xdebug.remote_enable=1
xdebug.remote_autostart=1
xdebug.remote_port=9000
# 开启所有站点xdebug调试
xdebug.remote_connect_back=1

首先进行简单的配置,xdebug的配置非常丰富,详细可以查看官方配置说明文档:https://xdebug.org/docs/all_settings,配置完成之后,需要保存,然后重启服务器(Apache或者nginx),然后在 phpinfo(); 中检查是否安装成功。

PHPStorm运行调试配置

PHPStorm服务器配置

如果跳过这一步,则下一步就需要手动添加服务器。如果在这儿配置了服务器,就可以在下一步中直接选择。
PHPStorm选择菜单:File -> Settings -> Language & Frameworks -> PHP -> Servers,点击那个绿色的 + 可以添加一个服务器配置,可以配置服务器的主机地址,端口一击调试器,详细可以参考下一步的截图。

PHPStorm运行项目配置

PHPStorm选择菜单:Run -> Edit Configurations;点击左上角的 + 添加配置,在候选框中选择 PHP Web Application,然后点击添加一个PHP项目实例。填写右边的相关信息,Start URL 为你的项目的访问地址,这个是需要在你的服务器(Apache或者nginx)中配置的。Server哪儿点击右边的三个点,可以添加一个服务器实例,注意填写的Host需要相同。

使用PHPStorm+XDebug搭建单步调试环境

PHPStorm调试配置

PHPStorm选择菜单:File -> Settings -> Language & Frameworks -> PHP -> Debug,点击Debug这一项,可以看到Debug的配置,一般这儿不用修改,只需要注意Debug port需要和你在PHP.ini中配置的port一致,并且勾选Can accept external connections。

PHPStorm进行单步调试

一切就绪,接下来就是单步调试了。可以通过点击PHPStorm中代码左边的位置设置断点,现在我们可以在 Laravel 网站根目录 Public 下的 index.php 开头设置一个断点,然后选择PHPStorm菜单:Run -> Debug "alaim" 进行调试,可以看到PHPStorm底部的信息框中答应出了所有变量的值。

使用PHPStorm+XDebug搭建单步调试环境

F8:单步,不跳入函数
F7:执行跳指令,跳入函数
Shift+F8:跳出函数
Alt+9:运行到指针处

PHP 相关文章推荐
WINDOWS 2000下使用ISAPI方式安装PHP
Sep 05 PHP
PHP中文分词的简单实现代码分享
Jul 17 PHP
Linux fgetcsv取得的数组元素为空字符串的解决方法
Nov 25 PHP
php解析html类库simple_html_dom(详细介绍)
Jul 05 PHP
ThinkPHP页面跳转success与error方法概述
Jun 25 PHP
php实现递归抓取网页类实例
Apr 03 PHP
PHP模拟asp中response类实现方法
Aug 08 PHP
WordPress过滤垃圾评论的几种主要方法小结
Jul 11 PHP
php cookie 详解使用实例
Nov 03 PHP
php unicode编码和字符串互转的方法
Aug 12 PHP
thinkPHP5使用Rabc实现权限管理
Aug 28 PHP
PHP中用Trait封装单例模式的实现
Dec 18 PHP
php利用云片网实现短信验证码功能的示例代码
Nov 18 #PHP
swoole和websocket简单聊天室开发
Nov 18 #PHP
php单元测试phpunit入门实例教程
Nov 17 #PHP
PHP开发之归档格式phar文件概念与用法详解【创建,使用,解包还原提取】
Nov 17 #PHP
PHP流Streams、包装器wrapper概念与用法实例详解
Nov 17 #PHP
PHP实现求两个字符串最长公共子串的方法示例
Nov 17 #PHP
PHP实现求解最长公共子串问题的方法
Nov 17 #PHP
You might like
PHP获取表单数据与HTML嵌入PHP脚本的实现
2017/02/09 PHP
thinkphp3.2实现在线留言提交验证码功能
2017/07/19 PHP
jquery自动完成插件(autocomplete)应用之PHP版
2009/12/15 Javascript
基于jQuery实现点击同时更改两个iframe的网址
2010/07/01 Javascript
可以用来调试JavaScript错误的解决方案
2010/08/07 Javascript
js 验证密码强弱的小例子
2013/03/21 Javascript
解决Jquery load()加载GB2312页面时出现乱码的两种方案
2013/09/10 Javascript
JS生成随机字符串的多种方法
2014/06/10 Javascript
node.js中的fs.createReadStream方法使用说明
2014/12/17 Javascript
Jquery实现鼠标移动放大图片功能实例
2015/03/25 Javascript
JavaScript获取当前网页最后修改时间的方法
2015/04/03 Javascript
jquery插件orbit.js实现图片折叠轮换特效
2015/04/14 Javascript
详解Bootstrap四种图片样式
2016/01/04 Javascript
深入浅析JavaScript中的作用域和上下文
2016/03/26 Javascript
js判断出两个字符串最大子串的函数实现方法
2016/11/01 Javascript
jQuery实现立体式数字动态增加(animate方法)
2016/12/21 Javascript
Bootstrap 3 按钮标签实例代码
2017/02/21 Javascript
微信小程序 MD5的方法详解及实例代码
2017/03/10 Javascript
微信小程序分页加载的实例代码
2017/07/11 Javascript
详解升级react-router 4 踩坑指南
2017/08/14 Javascript
Vue.js与 ASP.NET Core 服务端渲染功能整合
2017/11/16 Javascript
基于JavaScript中标识符的命名规则介绍
2018/01/06 Javascript
浅谈FastClick 填坑及源码解析
2018/03/02 Javascript
[03:41]DOTA2上海特锦赛小组赛第三日recap精彩回顾
2016/02/28 DOTA
django2 快速安装指南分享
2018/01/05 Python
Python笔记之观察者模式
2019/11/20 Python
python爬虫开发之使用Python爬虫库requests多线程抓取猫眼电影TOP100实例
2020/03/10 Python
一文解决django 2.2与mysql兼容性问题
2020/07/15 Python
网页布局中CSS样式无效的十个重要原因详解
2017/08/10 HTML / CSS
利用HTML5绘制点线面组成的3D图形的示例
2015/05/12 HTML / CSS
大一期末自我鉴定
2013/12/13 职场文书
电子商务应届生自我鉴定
2014/01/13 职场文书
事业单位辞职信范文
2014/01/19 职场文书
优秀食品类广告词
2014/03/19 职场文书
vue前端工程的搭建
2021/03/31 Vue.js
动画《新网球王子 U-17 WORLD CUP》希腊队PV公开
2022/04/02 日漫