我想将var_dump的输出捕获到一个字符串中。

PHP文档说;

与任何直接将结果输出到浏览器的操作一样,输出控制函数可用于捕获该函数的输出,并将其保存为字符串(例如)。

有什么例子可以说明它是如何工作的?

print_r()不是一个有效的可能性,因为它不会给我我需要的信息。


当前回答

我真的很喜欢var_dump()的详细输出,对var_export()的或print_r()的输出不满意,因为它没有提供尽可能多的信息(例如数据类型缺失,长度缺失)。

为了编写安全和可预测的代码,有时区分空字符串和null是有用的。或者在1和true之间。或者在null和false之间。我希望输出中有我的数据类型。

虽然很有帮助,但在现有的响应中,我没有找到一个干净简单的解决方案,可以将var_dump()的彩色输出转换为人类可读的输出,转换为一个没有html标记并包含var_dump()的所有细节的字符串。

注意,如果您有一个彩色的var_dump(),这意味着您已经安装了Xdebug,它会覆盖php的默认var_dump()来添加html颜色。

出于这个原因,我创造了这个轻微的变化,给我所需要的:

function dbg_var_dump($var)
    {
        ob_start();
        var_dump($var);
        $result = ob_get_clean();
        return strip_tags(strtr($result, ['=>' => '=>']));
    }

返回下面的nice字符串:

array (size=6)
  'functioncall' => string 'add-time-property' (length=17)
  'listingid' => string '57' (length=2)
  'weekday' => string '0' (length=1)
  'starttime' => string '00:00' (length=5)
  'endtime' => string '00:00' (length=5)
  'price' => string '' (length=0)

希望它能帮助到别人。

其他回答

这里是完整的解决方案作为一个函数:

function varDumpToString ($var)
{
    ob_start();
    var_dump($var);
    return ob_get_clean();
}

这可能有点跑题了。

我正在寻找一种方法将这类信息写入我的PHP-FPM容器的Docker日志中,并提出了下面的代码片段。我相信Docker PHP-FPM用户可以使用。

fwrite(fopen('php://stdout', 'w'), var_export($object, true));

如果希望在运行时查看变量的内容,可以考虑使用XDebug等真正的调试器。这样就不需要弄乱源代码,即使普通用户访问您的应用程序,也可以使用调试器。他们不会注意到的。

您也可以尝试使用serialize()函数。有时它对调试非常有用。

如果你使用PHP>=7.0.0

function return_var_dump(...$args): string
{
    ob_start();
    try {
        var_dump(...$args);
        return ob_get_clean();
    } catch (\Throwable $ex) {
        // PHP8 ArgumentCountError for 0 arguments, probably..
        // in php<8 this was just a warning
        ob_end_clean();
        throw $ex;
    }
}

或者如果你使用PHP >=5.3.0:

function return_var_dump(){
    ob_start();
    call_user_func_array('var_dump', func_get_args());
    return ob_get_clean();
}

或者如果你使用的是PHP<5.3.0(这个函数实际上一直兼容PHP4)

function return_var_dump(){
    $args = func_get_args(); // For <5.3.0 support ...
    ob_start();
    call_user_func_array('var_dump', $args);
    return ob_get_clean();
}

(在5.3.0之前,如果直接将func_get_args作为另一个函数调用的参数使用,则有一个错误,因此您必须将它放在变量中并使用变量,而不是直接将其作为参数使用..)