使用var_export()函数可以在服务端程序没有在打印的情况下,配合file_put_contents方便的调试程序,查看变量和数组的内容。
在开发过程中,我们常用var_dump()来打印数组内容,但有时候我们不方便通过浏览器查看调试信息,这时候可以将信息输出到文件中查看,var_export()可以打印或返回变量的字符串表示,返回值是一个字符串,形式类似var_dump()打印的字符串,使用var_export()可以将POST、GET和SESSION等数据写入文件,方便查看。
下面是php文档中的描述:
| mixed var_export ( mixed $expression [, bool $return ] ) |
|
此函数返回关于传递给该函数的变量的结构信息,它和 var_dump() 类似,不同的是其返回的表示是合法的 PHP 代码。 您可以通过将函数的第二个参数设置为 |
简而言之,第二个参数为TRUE时,有返回值,不打印;为FALSE时,打印变量,默认为FALSE
下面的示例使用var_export()将变量转换成字符串后输出:
<?php
$num = 255;
$str = 'abc def';
$bool = true;
$arr = array('value1', 'value2', 1, 'key1'=>'value3', 'key2'=>array(2, 3));
echo var_export($num, TRUE);
echo "
";
echo var_export($str, TRUE);
echo "
";
echo var_export($bool, TRUE);
echo "
";
echo var_export($arr, TRUE);
echo "
";
/*输出
255
'abc def'
true
array (
0 => 'value1',
1 => 'value2',
2 => 1,
'key1' => 'value3',
'key2' =>
array (
0 => 2,
1 => 3,
),
)
var_export()返回的是合法的php代码,非常方便生成配置文件或缓存文件,下面用简单的缓存文件示例来讲一下:
<?php
//$cache的值是更新缓存时从数据库中取出来的
$cache = array(
'LOG_RECORD' => false,
'LOG_TYPE' => 'File',
'LOG_LEVEL' => 'EMERG,ALERT,CRIT,ERR',
'LOG_FILE_SIZE' => 2097152,
'LOG_EXCEPTION_RECORD' => false,
);
//将从数据库中读到的数据写入缓存文件
$content = "<?php
return ".var_export($cache); //这里使用var_export()
file_put_contents('./cache.php', $content);
我们的缓存文件cache.php内容如下:
<?php
return array(
'LOG_RECORD' => false,
'LOG_TYPE' => 'File',
'LOG_LEVEL' => 'EMERG,ALERT,CRIT,ERR',
'LOG_FILE_SIZE' => 2097152,
'LOG_EXCEPTION_RECORD' => false,
);
调用缓存文件的时候只需要使用require()即可将缓存文件的内容复制给一个变量:
<?php
$cache = require('./cache.php');
缓存文件中的数组赋值给了$cache变量,phpcms的缓存文件就是采用这种方式的缓存。
