我正在做一个项目,其中全局变量在多个地方和各种文件中使用,并且遇到了全局变量的值不是我所期望的情况。很高兴知道一个函数,如果存在,它允许我获得全局变量的变化历史。
我希望该函数允许我获得与使用 debug_backtrace()
时相同的输出,不同之处在于它将传递变量的名称作为参数,并将返回结果,其中包含有关行号和文件名的信息对全局变量进行了更改。
如果到目前为止不存在这样的事情,那将是一个很好的黑客。提前谢谢。
如前所述,这并不容易实现。我建议你选择自己xdebug并将其用作远程/步骤调试器。话虽如此,您至少可以以某种方式进行一些自己的跟踪,但它是有代价的。
我举一个例子,首先从输出开始(这里是 CLI 脚本):
GLOBAL $argv[0] changed to: /path/to/global.php
GLOBAL $argc changed to: 1
GLOBAL $test changed to: 1
GLOBAL $test changed to: 2
GLOBAL $test changed to: 3
这是由以下人员生成的:
<?php
/**
* @link http://stackoverflow.com/questions/12895358/how-to-check-history-of-a-global-variable-in-php
*/
declare(ticks=1);
function array_diff_recursive(array $array1, array $array2) {
$diff = array();
foreach ($array1 as $key => $value) {
if (array_key_exists($key, $array2)) {
if (is_array($value) && is_array($array2[$key])) {
if ($result = array_diff_recursive($value, $array2[$key])) {
$diff[$key] = $result;
}
} else {
if ($value !== $array2[$key]) {
$diff[$key] = $value;
}
}
} else {
$diff[$key] = $value;
}
}
return $diff;
}
function globals_diff() {
static $last = array();
if (!isset($GLOBALS)) {
return;
}
$current = array();
$ignore = array_flip(array('_GET', '_POST', '_COOKIE', '_FILES', '_ENV', '_REQUEST', '_SERVER', 'GLOBALS'));
foreach($GLOBALS as $key => $value) {
isset($ignore[$key]) || $current[$key] = $value;
}
$diff = array_diff_recursive($current, $last);
foreach($diff as $var => $value) {
if (is_array($value) && $value) {
foreach($value as $array_key => $array_value) {
printf("GLOBAL $%s[%s] changed to: %sn", $var, $array_key, print_r($array_value, 1));
}
} else {
printf("GLOBAL $%s changed to: %sn", $var, print_r($value, 1));
}
}
$last = $current;
}
register_tick_function('globals_diff', true);
$test = 1;
$test = 2;
$test = 3;
这需要您启用刻度。否则,您可以使用全局函数进行快照。
如果要跟踪随时间推移的变化,则需要添加一些其他(全局)数据结构来存储这些更改(注意,这可能会变得很大),同时将其排除在比较之外(请参阅ingore列表)。