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

PHP文档说;

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

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

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


当前回答

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

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

其他回答

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

长字符串:只需使用echo($var);而不是dump($var);

对象或数组:var_dump(“< >之前”.json_encode ($ var)。”< / >之前);

尝试var_export

你可能想要检查var_export -虽然它不提供与var_dump相同的输出,但它提供了第二个$return参数,这将导致它返回输出而不是打印输出:

$debug = var_export($my_var, true);

Why?

与使用ob_start和ob_get_clean()相比,我更喜欢这个一行程序。我还发现输出更容易阅读,因为它只是PHP代码。

var_dump和var_export之间的区别在于var_export返回“变量的可解析字符串表示”,而var_dump只是转储关于变量的信息。在实践中,这意味着var_export为您提供了有效的PHP代码(但可能不会为您提供关于变量的足够多的信息,特别是在使用资源时)。

演示:

$demo = array(
    "bool" => false,
    "int" => 1,
    "float" => 3.14,
    "string" => "hello world",
    "array" => array(),
    "object" => new stdClass(),
    "resource" => tmpfile(),
    "null" => null,
);

// var_export -- nice, one-liner
$debug_export = var_export($demo, true);

// var_dump
ob_start();
var_dump($demo);
$debug_dump = ob_get_clean();

// print_r -- included for completeness, though not recommended
$debug_printr = print_r($demo, true);

输出的差异:

Var_export(上面例子中的$debug_export):

 array (
  'bool' => false,
  'int' => 1,
  'float' => 3.1400000000000001,
  'string' => 'hello world',
  'array' => 
  array (
  ),
  'object' => 
  stdClass::__set_state(array(
  )),
  'resource' => NULL, // Note that this resource pointer is now NULL
  'null' => NULL,
)

Var_dump(上面例子中的$debug_dump):

 array(8) {
  ["bool"]=>
  bool(false)
  ["int"]=>
  int(1)
  ["float"]=>
  float(3.14)
  ["string"]=>
  string(11) "hello world"
  ["array"]=>
  array(0) {
  }
  ["object"]=>
  object(stdClass)#1 (0) {
  }
  ["resource"]=>
  resource(4) of type (stream)
  ["null"]=>
  NULL
}

Print_r(上面例子中的$debug_printr):

Array
(
    [bool] => 
    [int] => 1
    [float] => 3.14
    [string] => hello world
    [array] => Array
        (
        )

    [object] => stdClass Object
        (
        )

    [resource] => Resource id #4
    [null] => 
)

注意:var_export不处理循环引用

如果你试图转储一个循环引用的变量,调用var_export将导致一个PHP警告:

 $circular = array();
 $circular['self'] =& $circular;
 var_export($circular);

结果:

 Warning: var_export does not handle circular references in example.php on line 3
 array (
   'self' => 
   array (
     'self' => NULL,
   ),
 )

另一方面,var_dump和print_r在遇到循环引用时会输出字符串*RECURSION*。

你也可以这样做:

$dump = print_r($variable, true);

如果你使用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作为另一个函数调用的参数使用,则有一个错误,因此您必须将它放在变量中并使用变量,而不是直接将其作为参数使用..)