PHP8.1.21版本已发布
vue8.1.21版本已发布
jquery8.1.21版本已发布

php CLI应用的调试方法(图文)

不言
不言 转载
2018-10-26 16:43:48 3519浏览

本篇文章给大家带来的内容是关于php cli应用的调试方法(图文),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

我们在Eclipse里选中一个PHP文件,右键选择Debug As->PHP CLI Application。

2345截图20181026163948.png

所谓CLI应用,是指这种脚本文件不需要任何Web服务器即可运行,当然, PHP运行时还是需要的。

我们在弹出的debug窗口里看到了XDebug:

2345截图20181026164033.png

XDebug是PHP调试的利器。在我的文件夹C:MyAppwampinphpphp5.5.12里面有个php.ini配置文件,文件的末尾有这样一个配置:

; XDEBUG Extension

zend_extension = "C:/MyApp/wamp/bin/php/php5.5.12/zend_ext/php_xdebug-2.2.5-5.5-vc11.dll"

;

[xdebug]

xdebug.remote_enable = off

xdebug.profiler_enable = off

xdebug.profiler_enable_trigger = off

xdebug.profiler_output_name = cachegrind.out.%t.%p

xdebug.profiler_output_dir = "C:/MyApp/wamp/tmp"

xdebug.show_local_vars=0

这里实际上就指明了XDEBUG的位置:

2345截图20181026164105.png

那么Eclipse?

使用任务管理器查看,当我用Eclipse调试PHP CLI应用时,出现了一个PHP.exe进程:

2345截图20181026164113.png

命令提示行:

C:MyAppwampinphpphp5.5.12php.exe -n -c C:Usersi042416AppDataLocalTempphp-inisession2307282238017995350.tmpphp.ini -d asp_tags=off -d short_open_tag=on C:Usersi042416scp20180425 est ewfile.php

-n 选项:不使用全局的php.ini文件

-c 选项:使用-c后面指定的php.ini, 即C:Usersi042416AppDataLocalTempphp-inisession2307282238017995350.tmpphp.ini

-d 选项:临时指定一个php.ini里没有的参数,即asp_tags=off

再看看这个我开始CLI调试后才临时生成的php.ini文件:

2345截图20181026164128.png

虽然有70多k,但是绝大多数是分号开头的注释,只有最后几行才是有效信息:

2345截图20181026164139.png

希望本文对大家理解Eclipse里使用XDebug进行PHP CLI应用的调试原理有所帮助。


声明:本文转载于:segmentfault,如有侵犯,请联系admin@php.cn删除