您好,欢迎访问一九零五行业门户网

PHP中有哪些debug方法

php中的debug(调试)方法有:1、在php代码中添加echo、var_dump、print_r和exit语句,通过浏览器打印信息进行调试;2、使用xdebug进行调试;3、通过console终端进行调试。
本教程操作环境:windows7系统、php7.1版、dell g3电脑
php常用的debug(调试)方式通过浏览器打印信息进行调试
方法
在代码中添加 echo、var_dump、print_r 和 exit,在浏览器中查看输出。
优缺点
优点:
简单,使用方便,不用安装插件对于自己写的代码,或比较熟悉的框架,可以这么用缺点:
对于多分支逻辑,需要加很多代码或尝试多次对于不熟悉的逻辑,无法反映出完整的执行流程。有可能将调试语句遗漏在项目中无法单步执行技巧
调试时,为了格式化输出变量,往往需要在项目中实现自己的 dump() 函数。利用 composer,可以全局安装 symfony/var-dumper 包中的 dump() 函数,使所有项目都可以使用,而无需改动项目。
全局安装 symfony/var-dumper 包:
默认会安装到 ${home}/.config/composer 目录composer global require symfony/var-dumper
修改 php.ini 文件,执行 php 代码之前先 include 指定的文件auto_prepend_file = ${home}/.config/composer/vendor/autoload.php
使用 xdebug 进行调试
xdebug 是 c/s 结构,其中 client 是 php 中安装的 xdebug,server 是 ide 中安装的插件,使用 dbgp 协议通信。php 运行脚本时,通过 xdebug 插件向 ide 发送调试信息,并接收 ide 发过来的控制信号。
需要为 php 安装并开启 xdebug,然后设置 ide 的 xdebug 插件,使二者可以通信。
优缺点
支持单步调试和任意变量值的获取配置复杂,需要 ide 安装插件支持跟浏览器的配合,需要请求中携带 xdebug_session_start 参数web app 调试
对于 web 应用,要开启 xdebug 调试模式,必须在浏览器发送的请求中添加额外的标志。可以在 get/post/cookie 参数中添加 xdebug_session_start=session_name,这样 xdebug 就明白这个请求需要调试,去连接 ide。
但每次手工设置也很麻烦,有两种方式简化操作:
使用 ide 提供的方式。对于 phpstorm,参考 debugging php web applications with run debug configurations。使用时需要配置好 ide 中的 web server,然后设置一个 php web application,点击 debug 按钮开始调试,这时 ide会自动打开浏览器并输好网址,并添加 xdebug_session_start=session_name。使用浏览器插件,打开插件的调试开关后,插件可以自动在请求中带上对应的 cookie。对于 chrome 可以安装 xdebug helper。通过 console 终端进行调试(cli 方式)
对于非 web 应用,例如定时任务或单元测试,可以直接在控制台进行调试。
phpstorm 中通过 alt+f12 快捷键打开命令行终端。但是因为 ide 中只能显示一个终端,在开启调试后的调试终端会覆盖命令行终端,所以还是单独开一个命令行终端吧(windows 下可以使用 dos 窗口或 powershell)。
方法及原理
web 应用通过 get/post/cookie 参数标志调试请求,而非 web 应用则通过在命令行终端设置环境变量来开启调试。
两步:
设置环境变量 xdebug_config="idekey=session_name",这个 idekey 需要跟 php.ini 中 xdebug 部分设置的 idekey 一样。在命令行终端执行脚本。执行时会唤起 ide 的 debug 终端,可以单步调试,输出结果实时显示在命令行终端。
ide通常提供快捷操作,对于 phpstorm 可以参考 debugging php cli scripts with phpstorm。
通过 ide 启动调试后,ide 会启动 xdebug 插件监听某个端口(phpstorm 默认是 9000,但是这跟 php-fpm 冲突了,可以改为 9001),获取 php 服务器返回的调试信息。
d:\lnmp\php72\php.exe -dxdebug.remote_enable=1 -dxdebug.remote_mode=req -dxdebug.remote_port=9001 -dxdebug.remote_host=127.0.0.1 d:\lihongfeng\workspace\untitled\index.php
设置、查看和释放环境变量linuxexport xdebug_config="idekey=session_name" // 设置环境变量echo $xdebug_config // 查看环境变量unset xdebug_config // 删除环境变量
windowsset xdebug_config="idekey=session_name" // 设置环境变量echo %xdebug_config% // 查看环境变量set xdebug_config // 查看环境变量set xdebug_config= // 删除环境变量
推荐学习:《php视频教程》
以上就是php中有哪些debug方法的详细内容。
其它类似信息

推荐信息