PHP调试常用五种方式:一、var_dump()显示变量结构;二、print_r()简洁打印数组对象;三、error_log()写入日志文件;四、debug_backtrace()追踪调用栈;五、xdebug_break()配合IDE断点调试。

如果您在开发PHP程序时需要查看变量值、执行流程或错误状态,则需要使用调试信息输出函数来辅助定位问题。以下是几种常用的PHP调试信息输出方式:
一、使用var_dump()函数
var_dump()用于显示变量的结构化信息,包括类型、值及数组嵌套层级,适合详细分析变量内容。
1、在代码中需要调试的位置插入var_dump($variable);语句。
2、确保PHP配置中display_errors为On,且error_reporting包含E_ALL。
立即学习“PHP免费学习笔记(深入)”;
3、若输出被截断或格式混乱,可配合echo "和";
echo "";包裹输出。
二、使用print_r()函数
print_r()以更简洁的方式打印数组和对象的内容,侧重可读性,不显示变量类型和资源ID。
1、在目标位置写入print_r($array_or_object);。
2、如需返回字符串而非直接输出,将第二个参数设为true:print_r($data, true)。
3、常与die()连用实现中断调试:print_r($data); die();。
三、使用error_log()函数
error_log()将调试信息写入服务器错误日志文件,适用于生产环境或需避免前端暴露调试内容的场景。
1、调用error_log("调试信息: " . print_r($data, true));。
2、确认PHP配置中log_errors为On,并检查error_log指定的日志路径是否可写。
3、可使用error_log("message", 3, "/path/to/debug.log")指定自定义日志文件。
四、使用debug_backtrace()函数
debug_backtrace()生成当前执行堆栈的数组,用于追踪函数调用链,排查逻辑跳转异常。
1、在可疑位置插入$trace = debug_backtrace(); var_dump($trace);。
2、可通过debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS)排除参数值以减小输出体积。
3、常用字段包括file、line、function、class,用于定位调用源头。
五、使用xdebug_break()函数(需启用Xdebug扩展)
xdebug_break()触发Xdebug断点,配合IDE进行交互式单步调试,支持变量监视与执行流控制。
1、确认php.ini中已加载Xdebug扩展并启用xdebug.mode=debug。
2、在代码中插入xdebug_break();语句作为断点位置。
3、启动IDE的调试监听,刷新页面后执行将在该行暂停,此时可实时查看所有作用域变量值。











