如何在PHP中检查全局变量的历史记录?
我在一个项目中工作,全局变量在多个位置和不同的文件中使用,并且遇到了全局变量的值不是我期望的值的情况。如果知道一个函数(如果存在的话)能让我得到一个全局变量的变化历史,那就太好了 我希望该函数能让我获得与使用如何在PHP中检查全局变量的历史记录?,php,debugging,global-variables,Php,Debugging,Global Variables,我在一个项目中工作,全局变量在多个位置和不同的文件中使用,并且遇到了全局变量的值不是我期望的值的情况。如果知道一个函数(如果存在的话)能让我得到一个全局变量的变化历史,那就太好了 我希望该函数能让我获得与使用debug_backtrace()时相同的输出例外情况是,它会将传递的变量的名称作为参数,并返回结果,其中包含对全局变量进行更改的行号和文件名的信息 如果到目前为止还不存在这样的东西,这将是一个很好的黑客工作。提前感谢。如前所述,这并不容易实现。我建议您选择自己的xdebug,并将其用作远程
debug_backtrace()时相同的输出
例外情况是,它会将传递的变量的名称作为参数,并返回结果,其中包含对全局变量进行更改的行号和文件名的信息
如果到目前为止还不存在这样的东西,这将是一个很好的黑客工作。提前感谢。如前所述,这并不容易实现。我建议您选择自己的xdebug,并将其用作远程/单步调试器。也就是说,你至少可以自己做一些跟踪,但这是有代价的 我举一个例子,首先从输出开始(这里是一个CLI脚本): 这是由以下因素产生的:
<?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: %s\n", $var, $array_key, print_r($array_value, 1));
}
} else {
printf("GLOBAL $%s changed to: %s\n", $var, print_r($value, 1));
}
}
$last = $current;
}
register_tick_function('globals_diff', true);
$test = 1;
$test = 2;
$test = 3;
这通常是调试器派上用场的地方。这样的东西是不存在的。这正是全局变量被视为坏做法的原因。如果全局变量是一个对象,您可以在类中构建一个历史记录机制,但是更好的方法是停止使用全局变量。无论如何。是的,我正要这么说,但是从整个项目中删除全局变量到现在是不可能的。。将尝试使用debuggerxdebug吗?没趣的蜱更令人兴奋!!
<?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: %s\n", $var, $array_key, print_r($array_value, 1));
}
} else {
printf("GLOBAL $%s changed to: %s\n", $var, print_r($value, 1));
}
}
$last = $current;
}
register_tick_function('globals_diff', true);
$test = 1;
$test = 2;
$test = 3;